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Preface 

This manual assumes some prior knowledge of current and proposed SCSI and PCI standards. For back¬ 
ground information, please contact: 

ANSI 

11 West 42nd Street 
New York, NY 10036 
(212) 642-4900 

Ask for document number X3.131-1994 (SCSI-2) 

Global Engineering Documents 

15 Inverness Way East 
Englewood, CO 80112 

(800) 854-7179 or (303) 792-2181 (outside U.S.) 

Ask for document number X3.131-1994 (SCSI-2) or X3.253 (SCSI-3 Parallel Interface) 

ENDL Publications 

14426 Black Walnut Court 
Saratoga, CA 95070 
(408) 867-6642 

Document names: SCSI Bench Reference, SCSI Encyclopedia 

Prentice Hall 

Englewood Cliffs, NJ 07632 
(201) 767-5937 

Ask for document number ISBN 0-13-796855-8, SCSI: Understanding the Small Computer System Interface 

Symbios Logic Electronic Bulletin Board 

(719) 533-7235 

SCSI Electronic Bulletin Board 

(719) 533-7950 

Symbios Logic Internet Anonymous FTP Site 

ftp.s5m1bios.com (204.131.200.1) 

Directory: /pub/symchips/scsi 

Symbios Logic World Wide Web Home Page 

http://www.s5mt1bios.com 

PCI Special Interest Group 

P.O. Box 10470 
Portland, OR 97214 

(800) 433-5177; (503) 797-4201 (International); FAX (503) 234-6762 

Symbios Logic PCI-SCSI Programming Guide 
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What is Covered in This Manual 


Chapter 1 

Introduction 


What is Covered in This 
Manual 

This manual provides reference information on the 
SYM53C895 PCI-SCSI I/O Processor. It is 
intended for system designers and programmers 
who are using this device to design a SCSI port for 
PCI-based personal computers, workstations, or 
embedded applications. 

■ This chapter includes general information 
about the SYM53C895 and other members of 
the SYM53C8XX family of PCI-SCSI I/O 
Processors. 

■ Chapter 2 describes the main functional areas 
of the chip in more detail, including the 
interfaces to the SCSI bus and external 
memory. 

■ Chapter 3 describes the chip’s connection to 
the PCI bus, including the PCI commands and 
configuration registers supported. 

■ Chapter 4 contains the pin diagrams and 
definitions of each signal. 

■ Chapter 5 describes each bit in the operating 
registers, organized by address. 

■ Chapter 6 defines all of the SCSI SCRIPTS 
instructions that are supported by the 
SYM53C895. 

■ Chapter 7 contains the electrical characteristics 
and AC timings for the chip. 

■ The appendixes contain a register summary, a 
mechanical drawing of the SYM53C895, and 
several example interface drawings to connect 
the SYM53C895 to an external ROM. 


This data manual assumes the user is familiar with 
the current and proposed standards for SCSI and 
PCI. For additional background information on 
these topics, please refer to the list of reference 
materials provided in the Preface of this docu¬ 
ment. 


General Description 

The SYM53C895 PCI-SCSI I/O Processor brings 
Ultra2 SCSI performance to host adapter, work¬ 
station, and general computer designs, making it 
easy to add a high-performance SCSI bus to any 
PCI system. It supports Ultra2 SCSI transfer rates 
and allows you to increase SCSI connectivity and 
cable length with Low Voltage Differential (LVD) 
signaling for SCSI. 

The SYM53C895 has a local memory bus for local 
storage of the device’s BIOS ROM in flash mem¬ 
ory or standard EPROMs. The SYM53C895 sup¬ 
ports Big and Little Endian byte addressing to 
accommodate a variety of data configurations. The 
SYM53C895 supports programming of local 
FLASH memory for updates to BIOS or 
SCRIPTS programs. The chip is packaged in a 
208-pin quad flat pack. System diagrams showing 
the connections of the SYM53C895 with an exter¬ 
nal ROM or flash memory are pictured in Appen¬ 
dix C. A block diagram of the SYM53C895 is 
pictured in Figure 1-1 on page 1-6. 

Symbios Logic LVDlink™ technology is the Sym- 
bios Logic implementation of LVD. LVDlink 
transceivers allow the SYM53C895 to perform 
single-ended and low voltage differential transfers, 
and support external high voltage differential 
transceivers.The SYM53C895 integrates a high- 
performance SCSI core, a PCI bus master DMA 
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Benefits of LVDIink 


core, and the Symbios Logic SCSI SCRIPTS™ 
processor to meet the flexibility requirements of 
SCSI-3 and Ultra2 SCSI standards. It is designed 
to implement multi-threaded I/O algorithms with a 
minimum of processor intervention, solving the 
protocol overhead problems of previous intelligent 
and non-intelligent adapter designs. 


New Features in 
the SYM53C895 

The SYM53C895 is functionally similar to the 
SYM53C875 PCI-SCSI I/O processor, with added 
support for Ultra2 SCSI. Some software enhance¬ 
ments, and use of LVD, are needed to enable the 
chip to transfer data at Ultra2 SCSI transfer rates. 
Most of the feature enhancements in the 
SYM53C895 are included to enable the chip to 
take advantage ofUltra2 SCSI transferrates. 

■ Optional 816-byte DMA FIFO supports large 
block transfers at Ultra2 SCSI speeds. The 
default FIFO size is 112 bytes. 

■ 31 levels of SCSI Synchronous Offset increases 
the pace of synchronous transfers to match 
Ultra2 SCSI transfer speeds 

■ On-chip LVDIink transceivers allow increased 
connectivity, longer cable length, and 
improved performance. They also 
automatically sense the type of device 
connected to the SCSI bus and switch as 
needed to single-ended, LVD, or high voltage 
differential mode (if the chip is connected to 
external transceivers). 

■ On-chip SCSI clock quadrupler to achieve 160 
MHz frequency with an external 40MHz 
oscillator 

■ Support for Subsystem ID and .Subsystem 
Vendor ID registers in PCI configuration space 

■ Support for serial EEPROM interface 


Benefits of LVDIink 

The SYM53C895 supports low voltage differential 
(LVD) for SCSI, a signaling technology that 
increases the reliability of SCSI data transfers over 
longer distances than supported by single-ended 
SCSI. The low current output of LVD allows the 
I/O transceivers to be integrated directly onto the 
chip. LVD provides the reliability of high voltage 
differential SCSI without the added cost of exter¬ 
nal differential transceivers. Ultra2 SCSI with 
LVD allows a longer SCSI cable and more devices 
on the bus, with the same cables defined in the 
SCSI-3 Parallel Interface standard for Fast-20 
(Ultra SCSI). LVD provides a long-term migration 
path to even faster SCSI transfer rates without 
compromising signal integrity, cable length, or 
connectivity. 

For backward compatibility to existing single- 
ended devices, the SYM53C895 features universal 
LVDIink transceivers that can switch between LVD 
SCSI and single-ended modes. The LVDIink tech¬ 
nology also supports high-power differential sig¬ 
naling in legacy systems, when external 
transceivers are connected to the SYM53C895. 
This allows the SYM53C895 to be used in both 
legacy and Ultra2 SCSI applications. 
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Benefits of Ultra2 SCSI 

Ultra2 SCSI is an extension of the SPI-2 draft 
standard that allows faster synchronous SCSI 
transfer rates and defines a new physical layer, 

LVD SCSI, that provides an incremental evolution 
from SCSI-2 and Ultra SCSI. When enabled, 
Ultra2 SCSI performs 40 megatransfers per sec¬ 
ond, which results in approximately double the 
synchronous transfer rates of Ultra SCSI. The 
SYM53C895 can perform 16-bit, Ultra2 SCSI 
synchronous transfers as fast as 80 MB/s.This 
advantage is most noticeable in heavily loaded sys¬ 
tems, or large-block size applications such as video 
on-demand and image processing. 

One advantage of Ultra2 SCSI is that it signifi¬ 
cantly improves SCSI bandwidth while preserving 
existing hardware and software investments. The 
primary software changes required are to enable 
the chip to perform synchronous negotiations for 
Ultra2 SCSI rates, and to enable the clock quadru- 
pler. Ultra2 SCSI uses the same connectors as 
Ultra SCSI, but can operate with longer cables and 
more devices on the bus. Chapter 2 contains more 
information on migrating an Ultra SCSI design to 
support Ultra2 SCSI. 


TolerANT Technology 

The SYM53C895 features TolerANT® technol¬ 
ogy, which includes active negation on the SCSI 
drivers and input signal filtering on the SCSI 
receivers. Active negation causes the SCSI 
Request, Acknowledge, Data, and Parity signals to 
be actively driven high rather than passively pulled 
up by terminators. Active negation is enabled by 
setting bit 7 in the STEST3 register. 

TolerANT receiver technology improves data 
integrity in unreliable cabling environments, where 
other devices would be subject to data corruption. 
TolerANT receivers filter the SCSI bus signals to 
eliminate unwanted transitions, without the long 
signal delay associated with RC-type input filters. 
This improved driver and receiver technology 
helps eliminate double clocking of data, the single 
biggest reliability issue with SCSI operations. 
TolerANT input signal filtering is a built in feature 
of the SYM53C895 and all Symbios Logic Fast 
SCSI, Ultra SCSI, and Ultra2 SCSI devices. On 
the SYM53C895, the user can select a filtering 
period of 30 or 60 ns, with bit 1 in the STEST2 
register. 

The benefits ofTolerANT include increased 
immunity to noise when the signal is going high, 
better performance due to balanced duty cycles, 
and improved fast SCSI transfer rates. In addition, 
TolerANT SCSI devices do not cause glitches on 
the SCSI bus at power up or power down, so other 
devices on the bus are also protected from data 
corruption. When it is used with the LVDlink 
transceivers,TolerANT provides excellent signal 
quality and data reliability in real world cabling 
environments. TolerANT is compatible with both 
the Alternative One and Alternative Two termina¬ 
tion schemes proposed by the American National 
Standards Institute. 
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SYM53C895 Benefits 
Summary 

SCSI Performance 

■ Integrated LVDlink universal transceivers 

■ Support single ended, LVD, and high 
voltage differential signals (with external 
transceivers) 

■ Allow greater device connectivity and 
longer cable length 

■ LVDlink transceivers save cost of external 
differential transceivers 

■ Support a long-term performance 
migration path 

■ With 816-byte FIFO, chip can burst up to 512 
bytes across the PCI bus 

■ Performs wide, Ultra 2 SCSI synchronous 
transfers as fast as 80 MB/s 

■ On-chip SCSI clock quadrupler allows the 
chip to achieve Ultra 2 SCSI transfer rates with 
40MHz clock 

■ Includes 4KB internal RAM for SCRIPTS 
instruction storage 

■ 31 levels of SCSI synchronous offset 

■ Supports variable block size and scatter/gather 
data transfers. 

■ Performs sustained memory-to-memory 
DMA transfers faster than 47 MB/s (@ 33 
MHz) 

■ Minimizes SCSI I/O start latency 

■ Performs complex bus sequences without 
interrupts, including restore data pointers 

■ Reduces ISR overhead through a unique 
interrupt status reporting method 

■ Load and Store SCRIPTS instruction 
increases performance of data transfers to and 
from chip registers 


■ Supports target disconnect and later reconnect 
with no interrupt to the system processor 

■ Supports multi-threaded I/O algorithms in 
SCSI SCRIPTS with fast I/O context 
switching 

■ Expanded Register Move instruction supports 
additional arithmetic capability 

PCI Performance 

■ Complies with PCI 2.1 specification 

■ 32-bit 33 MHz PCI interface 

■ Bursts 2 ,4, 8 , 16,32,64, or 128 dwords across 
PCI bus 

■ Supports 32-bit word data .bursts with variable 
burst lengths. 

■ Pre-fetches up to 8 dwords of SCRIPTS 
instructions 

■ Bursts SCRIPTS op code fetches across the 
PCI bus 

■ Performs zero wait-state bus master data bursts 
faster than 110 MB/s (@ 33 MHz) 

■ Supports PCI Cache Line Size register 

■ Supports PCI Write and Invalidate, Read 
Line, and Read Multiple commands 

Integration 

■ Integrated LVD transceivers 

■ Full 32-bit PCI DMA bus master 

■ Can be used as a third-party PCI bus DMA 
controller by using Memory to Memory Move 
instructions 

■ High performance SCSI core 

■ Integrated SCRIPTS processor 

Ease of Use 

■ Up to one megabyte of add-in memory 
support for BIOS and SCRIPTS storage 

■ Direct PCI-to-SCSI connection 
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Introduction 

SYM53C895 Benefits Summary 


■ Reduced SCSI development effort 

■ Compiler-compatible with existing 
SYM53C7XX and SYM53C8XX family 
SCRIPTS 

■ Direct connection to PCI, and SCSI single- 
ended and differential buses 

■ Development tools and sample SCSI 
SCRIPTS available 

■ Maskable and pollable interrupts 

■ Wide SCSI, A or P cable, and up to 16 devices 
supported 

■ Three programmable SCSI timers: Select/ 
Reselect, Handshake-to-Handshake, and 
General Purpose. The time-out period is 
programmable from 100 ps to greater than 
25.6 seconds 

■ Software for PC-based operating system 
support 

■ Support for relative jumps 

■ SCSI Selected As ID bits for responding with 
multiple IDs 


Flexibility 

■ Universal LVD transceivers are backward 
compatible with single-ended or high-power 
differential devices 

■ High level programming interface (SCSI 
SCRIPTS) 

■ Programs local memory bus FLASH memory 

■ Big/Little Endian support 

■ Selectable 112 - or 816-byte DMA FIFO for 
backward compatibility 

■ Tailored SCSI sequences execute from main 
system RAM or internal SCRIPTS RAM 

■ Flexible programming interface to tune I/O 
performance or to adapt to unique SCSI 
devices 

■ Support for changes in the logical I/O interface 
definition 


Low level access to all registers and all SCSI 
bus signals 

Fetch, Master, and Memory Access control 
pins 

Separate SCSI and system clocks 

SCSI clock quadrupler bits enable Ultra 2 
SCSI transfer rates with a 40 MHz SCSI clock 

Selectable IRQ pin disable bit 

Ability to route system clock to SCSI clock 


Reliability 

■ 2 KV ESD protection on SCSI signals 

■ Protection against bus reflections due to 
impedance mismatches 

■ Controlled bus assertion times (reduces RFI, 
improves reliability, and eases FCC 
certification) 

■ Latch-up protection greater than 150 mA 

■ Voltage feed through protection (minimum 
leakage current through SCSI pads) 

■ More than 25% of pins are power and ground 

■ Power and ground isolation of I/O pads and 
internal chip logic 

■ TolerANT technology provides: 

■ Active negation of SCSI Data, Parity, 
Request, and Acknowledge signals for 
improved fast SCSI transfer rates 

■ Input signal filtering on SCSI receivers 
improves data integrity, even in noisy 
cabling environments 


Testability 

■ All SCSI signals accessible through 
programmed I/O 

■ SCSI loopback diagnostics 

■ SCSI bus signal continuity checking 

■ Support for single-step mode operation 

■ Test mode (AND tree) to check pin continuity 
to the board 
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SYM53C895 Benefits Summary 


PCI 



SCSI Bus 


Figure 1-1: SYM53C895 Chip Block Diagram 
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Functional Description 

SCSI Core 


Chapter 2 

Functional Description 


The SYM53C895 contains three functional 
blocks: the SCSI Core, the DMA Core, and the 
SCRIPTS Processor. Symbios Logic supplies soft¬ 
ware that supports the SYM53C895 and the entire 
Symbios Logic product line of SCSI processors 
and controllers. 


SCSI Core 

The SCSI core supports an 8- or 16-bit data bus. 
It supports Ultra2 SCSI synchronous transfer rates 
up to 80 MB/s on a 16-bit, LVD SCSI bus. The 
SCSI core can be programmed with SCSI 
SCRIPTS, making it easy to “fine tune” the sys¬ 
tem for specific mass storage devices or SCSI-3 
requirements. 

The SCSI core offers low-level register access or a 
high-level control interface. Like first generation 
SCSI devices, the SYM53C895 SCSI core can be 
accessed as a register-oriented device. The ability 
to sample and/or assert any signal on the SCSI bus 
can be used in error recovery and diagnostic proce¬ 
dures. In support of loopback diagnostics, the 
SCSI core may perform a self-selection and oper¬ 
ate as both an initiator and a target. 

The SYM53C895 SCSI core is controlled by the 
integrated SCRIPTS processor through a high- 
level logical interface. Commands controlling the 
SCSI core are fetched out of the main host mem¬ 
ory or local memory. These commands instruct the 
SCSI core to transfer information, change bus 
phases and, in general, implement all aspects of 
the SCSI protocol. The SCRIPTS processor is a 
special high-speed processor optimized for SCSI 
protocol. 


DMA Core 

The DMA core is a bus master DMA device that 
attaches directly to the industry standard PCI Bus. 
The DMA core is tightly coupled to the SCSI core 
through the SCRIPTS processor, which supports 
uninterrupted scatter/gather memory operations. 

The SYM53C895 supports 32-bit memory and 
automatically supports misaligned DMA transfers. 
A 112- or 816-byte FIFO allows the SYM53C895 
to support 2, 4, 8, 16, 32, 64, or 128 dword bursts 
across the PCI bus interface. 


SCRIPTS Processor 

The SCSI SCRIPTS processor allows both DMA 
and SCSI commands to be fetched from host 
memory or internal SCRIPTS RAM. Algorithms 
written in SCSI SCRIPTS control the actions of 
the SCSI and DMA cores and are executed from 
32-bit system RAM or internal SCRIPTS RAM. 
The SCRIPTS processor executes complex SCSI 
bus sequences independently of the host CPU. 

The SCRIPTS processor can begin a SCSI I/O 
operation in approximately 500 ns. Algorithms 
may be designed to tune SCSI bus performance, to 
adjust to new bus device types (such as scanners, 
communication gateways, etc.), or to incorporate 
changes in the SCSI-2 or SCSI-3 logical bus defi¬ 
nitions without sacrificing TO performance. SCSI 
SCRIPTS are hardware- independent, so they can 
be used interchangeably on any host or CPU sys¬ 
tem bus. 


SYM53C895 Data Manual 


2-1 



Functional Description 

Designing an Ultra2 SCSI System 


Internal 

SCRIPTS RAM 

The SYM53C895 has 4 KB (1024 x 32 bits) of 
internal, general purpose RAM, The RAM is 
designed for SCRIPTS program storage, but is not 
limited to this type of information. When the chip 
fetches SCRIPTS instructions or Table Indirect 
information from the internal RAM, these fetches 
remain internal to the chip and do not use the PCI 
bus. Other types of access to the RAM by the 
SYM53C895 use the PCI bus as if they were exter¬ 
nal accesses. The MAD5 pin enables the 4K inter¬ 
nal RAM, when it is connected to Vdd through a 
4.7 K£2 resistor. To disable the internal RAM, con¬ 
nect a 4.7K LI resistor between the MAD5 pin and 

v ss . 

The RAM can be relocated by the PCI system 
BIOS anywhere in 32-bit address space.The RAM 
Base Address register in PCI configuration space 
contains the base address of the internal RAM. 
This register is similar to the ROM Base Address 
register in PCI configuration space. To simplify 
loading of SCRIPTS instructions, the base address 
of the RAM will appear in the SCRATCHB regis¬ 
ter when bit 3 of the CTEST2 register is set. The 
RAM is byte-accessible from the PCI bus and will 
be visible to any bus-mastering device on the bus. 
External accesses to the RAM (i.e., by the CPU) 
follow the same timing sequence as a standard 
slave register access, except that the target wait 
states required will drop from 5 to 3. 

A complete set of development tools is available for 
writing custom drivers with SCSI SCRIPTS. For 
more information on the SCSI SCRIPTS instruc¬ 
tions supported by the SYM53C895, see Chapter 
6 . 


Designing an Ultra2 SCSI 
System 

Since Ultra2 SCSI is based on existing SCSI stan¬ 
dards, it can use existing driver programs as long 
as the software is able to negotiate for Ultra2 SCSI 
synchronous transfer rates. Additional software 
modifications may be needed to take advantage of 
the new features in the SYM53C895. 

In the area of hardware, LVD SCSI is required to 
achieve Ultra2 SCSI transfer rates and to support 
the longer cable and additional devices on the bus. 
All devices on the bus must have LVD SCSI to 
guarantee Ultra2 SCSI transfer rates. For addi¬ 
tional information on Ultra2 SCSI, refer to the 
SPI-2 working document which is available from 
the SCSI BBS referenced at the beginning of this 
manual. Chapter 7 contains Ultra2 SCSI timing 
information. In addition to the guidelines in the 
draft standard, make the following software and 
hardware adjustments to accommodate Ultra2 
SCSI transfers: 

■ Set the Ultra Enable bit to enable Ultra2 SCSI 
transfers. 

■ Set the TolerANT Enable bit, bit 7 in the 
STEST3 register, whenever the Ultra Enable 
bit is set. 

■ Do not extend the SREQ/SACK filtering 
period with STEST2 bit 1. When the Ultra 
Enable bit is set, the filtering period will be 
fixed at 8ns for Ultra2 SCSI or 15 ns for Ultra 
SCSI, regardless of the value of the SREQ/ 
SACK Filtering bit. 

■ Use the SCSI clock quadruples 
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Functional Description 

Prefetching SCRIPTS Instructions 


Using the SCSI 
Clock Quadrupler 

The SYM53C895 can quadruple the frequency of 
a 40 MHz SCSI clock, allowing the system to per¬ 
form Ultra2 SCSI transfers. This option is user- 
selectable with bit settings in the STEST1, 
STEST3, and SCNTL3 registers. At power-on or 
reset, the quadrupler is disabled and powered 
down. Follow these steps to use the clock quadru¬ 
ple 

1 . Set the SCLK Quadrupler Enable bit 
(STEST1, bit 3) 

2 . Poll bit 5 of the STEST4 register. The 
SYM53C895 sets this bit as soon as it locks in 
the 160 MHz frequency. The frequency lockup 
takes approximately 100 microseconds. 

3. Halt the SCSI clock by setting the Halt SCSI 
Clock bit (STEST3 bit 5) 

4. Set the clock conversion factor using the SCF 
and CCF fields in the SCNTL3 register 

5. Set the SCLK Quadrupler Select bit 
(STEST1, bit 2) 

6 . Clear the Halt SCSI Clock bit 


Prefetching SCRIPTS 
Instructions 

When enabled (by setting the Prefetch Enable bit 
in the DCNTL register), the prefetch logic in the 
SYM53C895 fetches 8 dwords of instructions. The 
prefetch logic automatically determines the maxi¬ 
mum burst size that it can perform, based on the 
burst length as determined by the values in the 
DMODE register. If the burst size is less than four 
dwords, the SYM53C895 performs normal 
instruction fetches. While the SYM53C895 is 
prefetching SCRIPTS instructions the PCI Cache 
Line Size register value does not have any effect 
and the Read Line, Read Multiple, and Write and 
Invalidate commands will not be used. 

The SYM53C895 may flush the contents of the 
prefetch buffer under certain conditions, listed 
below, to ensure that the chip always operates from 
the most current version of the software. When one 
of these conditions apply, the contents of the 
prefetch buffer are flushed automatically. 

1 . On every Memory Move instruction. The 
Memory Move instruction is often used to 
place modified code directly into memory. To 
make sure that the chip executes all recent 
modifications, the prefetch buffer flushes its 
contents and loads the modified code every 
time an instruction is issued. To avoid 
inadvertently flushing the prefetch buffer 
contents, use the No Flush option for all 
Memory Move operations that do not modify 
code within the next 8 dwords. For more 
information on this instruction, refer to 
Chapter 6. 

2 . On every Store instruction. The Store 
instruction may also be used to place modified 
code directly into memory. To avoid 
inadvertently flushing the prefetch buffer 
contents, use the No Flush option for all Store 
operations that do not modify code within the 
next 8 dwords. 
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Functional Description 

Parallel ROM Interface 


3. On every write to the DSP, 

4. On all Transfer Control instructions when the 
transfer conditions are met. This is necessary 
because the next instruction to be executed is 
not the sequential next instruction in the 
prefetch buffer, 

5. When the Pre-Fetch Flush bit (DCNTL bit 6) 
is set. The buffer flushes whenever this bit is 
set. The bit is self-clearing. 


Op Code Fetch 
Burst Capability 

Setting the Burst Op Code Fetch Enable bit in the 
DMODE register (38h) causes the SYM53C895 
to burst in the first two dwords of all instruction 
fetches. If the instruction is a memory-to-memory 
move* the third dword will be accessed in a sepa¬ 
rate ownership. If the instruction is an indirect 
type* the additional dword will be accessed in a 
subsequent bus ownership. If the instruction is a 
table indirect block move, the SYM53C895 will 
use two accesses to obtain the four dwords 
required, in two bursts of two dwords each. 

Note: this feature only works if pre-fetching is 
disabled. 


Parallel ROM Interface 

The SYM53C895 supports up to one megabyte of 
external memory in binary increments from 16 
KB, to allow the use of expansion ROM for add-in 
PCI cards. The device also supports flash ROM 
updates through the add-in interface and the 
GPI04 pin (used to control Vpp, the power supply 
for programming external memory). This interface 
is designed for low-speed operations such as down¬ 
loading instruction code from ROM; it is not 
intended for dynamic activities such as executing 
instructions. 

System requirements include the SYM53C895, 
two or three external 8-bit address holding regis¬ 
ters (HCT273 or HCT374), and the appropriate 
memory device.The 4.7 K£2 resistors on the MAD 
bus require HC or HCT external components to 


be used. If in-system flash ROM updates are 
required, a 7406 (high voltage open collector 
inverter), an MTD4P05, and several passive com¬ 
ponents are also needed. The memory size and 
speed is determined by pull-up/pull-down configu¬ 
ration on the 8-bit bidirectional memory bus at 
power up.The SYM53C895 senses this bus 
shortly after the release of the Reset signal and 
configures the ROM Base Address register and the 
memory cycle state machines for the appropriate 
conditions. 

The SYM53C895 supports a variety of sizes and 
speeds of expansion ROM, using pull-up and pull¬ 
down resistors on the MAD(3-0) pins. The encod¬ 
ing of pins MAD(3-1) allows the user to define 
how much external memory is available to the 
SYM53C895. Table 2-1 shows the memory space 
associated with the possible values of MAD(3-1). 
The MAD(3-1) pins are fully defined in Chapter 
4, “Signal Descriptions.” Appendix C an example 
set of interface drawings. 


Table 2-1: External Memory Support 


MAD(3-1) 

Available Memory Space 

000 

16 KB 

001 

32 KB 

010 

64 KB 

Oil 

128 KB 

100 

256 KB 

101 

512 KB 

110 

1024 KB 

111 

no external memory present 


To use one of the configurations mentioned above 
in a host adapter board design, put 4.7 K12 pull-up 
and pull-down resistors on the appropriate MAD 
pins, corresponding to the available memory 
space. For example, to connect to a 32 KB exter¬ 
nal ROM, use pull-downs on MAD(3) and 
MAD(2) and a pull-up on MAD(l). 

Note: the SYM53C875 contained internal pull- 
ups on the MAD bus. The SYM53C895 
requires external resistors to pull up the 
MAD bus to Vj)]> 
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Functional Description 

Serial EEPROM Interface 


The SYM53C895 allows the system to determine 
the size of the available external memory using the 
Expansion ROM Base Address register in PCI 
configuration space. For more information on how 
this works, refer to the PCI specification or the 
Expansion ROM Base Address register description 
in Chapter 3. 

MAD(O) is the slow ROM pin. When pulled down, 
it enables two extra clock cycles of data access time 
to allow use of slower memory devices. 

The external memory interface also supports 
updates to flash memory. The 12 volt power supply 
for flash memory, Vpp, is enabled and disabled 
with the GPI04 pin and the GPI04 control bit. 
For more information on the GPI04 pin, refer to 
Chapter 4. 


Serial EEPROM Interface 

The SYM53C895 implements an interface which 
allows attachment of a serial EEPROM device to 
the GPIOO and GPIOl pins. Four different modes 
of operation are possible; each one relates to differ¬ 
ent values for the serial EEPROM interface, the 
Subsystem ID Register, and the Subsystem Vendor 
ID register. The modes are programmable through 
the MAD6 and MAD? pins, which are sampled at 
power-up or hard reset. 


Mode A: 

4.7 KQ pull-ups on MAD 6 and MAD7 

In this mode, GPIOO is the serial data signal 
(SDA) and GPIOl is the serial clock signal (SCL). 
Certain data in the serial EEPROM is automati¬ 
cally loaded into chip registers at power-up or hard 
reset. 

The format of the serial EEPROM data is defined 
in Table 2-2. If the EEPROM is not present, or the 
checksum fails, the Subsystem ID and Subsystem 


Vendor ID registers read back all zeroes. At power- 
up or hard reset, only five bytes are loaded into the 
chip from locations OOh through 04h. 


Table 2-2: Mode A Serial EEPROM Data Format 


Byte 

Description 

OOh 

Subsystem Vendor ID, LSB. This byte 
is loaded into the least significant byte 
of the Subsystem Vendor ID register in 
PCI configuration space at chip 
power-up or hard reset. 

Olh 

Subsystem Vendor ID, MSB. This byte 
is loaded into the most significant byte 
of the Subsystem Vendor ID register in 
PCI configuration space at chip 
power-up or hard reset. 

02h 

Subsystem ID, LSB. This byte is 
loaded into the least significant byte of 
the Subsystem ID register in PCI con¬ 
figuration space at chip power-up or 
hard reset. 

03h 

Subsystem ID, MSB. This byte is 
loaded into the most significant byte of 
the Subsystem ID register in PCI con¬ 
figuration space at chip power-up or 
hard reset. 

04h 

Checksum. This 8-bit checksum is 
formed by adding, bytewise, each byte 
contained in locations 00h-03h to the 
seed value 55h, and then taking the 2’s 
compliment of the result. 

05h - FFh 

Reserved 

lOOh-EOM 

User Data 


Mode B: 

4.7 K Q. pull-down on MAD 6, 

4.7 KQ pull-up on MAD 7 

In this mode, GPIOO and GPIO1 are each defined 
as either the serial data signal (SDA) or the serial 
clock signal (SCL), since both pins are controlled 
through software. 

No data is automatically loaded into chip registers 
at power-up or hard reset. The Subsystem ID reg¬ 
ister and Subsystem Vendor ID registers are read/ 
write, in violation of the PCI specification, with a 
default value of all zeroes. 
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Functional Description 

PCI Cache Mode 


Mode C: 

4.7 K Q pull-downs on MAD6 and MAD7 

In this mode* GPIO1 is the serial data signal 
(SDA) and GPIOO is the serial clock signal (SCL). 
Certain data in the serial EEPROM is automati¬ 
cally loaded into chip registers at power-up or hard 
reset. 

The format of the serial EEPROM data is defined 
in Table 2-3. If the EEPROM is not present* or the 
checksum fails* the Subsystem ID and Subsystem 
Vendor ID registers read back all zeroes. At power- 
up or hard reset* only five bytes are loaded into the 
chip from locations FBh through FFh. 

Table 2-3: Mode C Serial EEPROM Data Format 

Byte Description 

00h - FAh User Data 

FBh Subsystem Vendor ID, LSB.This byte 

is loaded into the least significant byte 
of the Subsystem Vendor ID register in 
PCI configuration space at chip 
power-up or hard reset. 


Mode D: 4.7 KQ pull-up on MAD6, 

4.7 K Q pull-down on MAD7 

This is a reserved mode and should not be used. It 
may be redefined in future devices. 


PCI Cache Mode 

The SYM53C895 supports the PCI specification 
for an 8-bit Cache Line Size register located in 
PCI configuration space. The Cache Line Size reg¬ 
ister provides the ability to sense and react to non- 
aligned addresses corresponding to cache line 
boundaries. In conjunction with the Cache Line 
Size register* the PCI commands Read Line* Read 
Multiple* and Write and Invalidate are each soft¬ 
ware enabled or disabled to allow the user full flex¬ 
ibility in using these commands. For more 
information on PCI cache mode operations* refer 
to Chapter 3. 


FCh Subsystem Vendor ID, MSB. This byte 

is loaded into the most significant byte 
of the Subsystem Vendor ID register in 
PCI configuration space at chip 
power-up or hard reset. 

FDh Subsystem ID* LSB.This byte is 

loaded into the least significant byte of 
the Subsystem ID register in PCI con¬ 
figuration space at chip power-up or 
hard reset. 

FEh Subsystem ID* MSB. This byte is 

loaded into the most significant byte of 
the Subsystem ID register in PCI con¬ 
figuration space at chip power-up or 
hard reset. 

Checksum. This 8-bit checksum is 
formed by adding* bytewise* each byte 
contained in locations FBh-FEh to the 
seed value 55h* and then taking the 2’s 
compliment of the result. 

User Data 


FFh 


lOOh-EOM 
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Big and Little Endian Support 


Big and Little Endian 
Support 

The SYM53C895 supports both Big and Little 
Endian byte ordering through pin selection* In Big 
Endian mode, the first byte of an aligned SCSI-to- 
PCI transfer will be routed to lane three and suc¬ 
ceeding transfers will be routed to descending 
lanes* This mode of operation also applies to data 
transfers over the add-in ROM interface*The byte 
of data accessed at location OOOOh from memory is 
routed to lane three, and the data at location 
0003h is routed to byte lane 0. In Little Endian 
mode, the first byte of an aligned SCSI to PCI 
transfer will be routed to lane zero and succeeding 
transfers will be routed to ascending lanes. This 
mode of operation also applies to the add-in ROM 
interface* The byte of data accessed at location 
OOOOh from memory is routed to lane zero, and the 
data at location 0003h is routed to byte lane 3. 

The Big_Lit pin gives the SYM53C895 the flexi¬ 
bility of operating with either Big or Little Endian 
byte orientation. Internally, in either mode, the 
actual byte lanes of the DMA FIFO and registers 
are not modified.The SYM53C895 supports slave 
accesses in Big or Little Endian mode. 

When a dword is accessed, no repositioning of the 
individual bytes is necessary since dwords are 
addressed by the address of the least significant 
byte. SCRIPTS always uses dwords in 32-bit sys¬ 
tems, so compatibility is maintained between sys¬ 
tems using different byte orientations. When less 
than a dword is accessed, individual bytes must be 
repositioned. Internally, the SYM53C895 adjusts 
the byte control logic of the DMA FIFO and regis¬ 
ter decodes to access the appropriate byte lanes. 
The registers will always appear on the same byte 
lane, but the address of the register will be reposi¬ 
tioned. 

Big/Little Endian mode selection has the most 
effect on individual byte access. Internally, the 
SYM53C895 adjusts the byte control logic of the 
DMA FIFO and register decodes to enable the 
appropriate byte lane. The registers will always 
appear on the same byte lane, but the address of 
the register will be repositioned. 


Data to be transferred between system memory 
and the SCSI bus always starts at address zero and 
continues through address ‘n 3 - there is no byte 
ordering in the chip. The first byte in from the 
SCSI bus goes to address 0, the second to address 
1, etc. Going out onto the SCSI bus, address zero 
is the first byte out on the SCSI bus, address 1 is 
the second byte, etc. The only difference is that in 
a Little Endian system, address 0 will be on byte 
lane 0, and in Big Endian mode address zero will 
be on byte lane 3. 

Correct SCRIPTS will be generated if the 
SCRIPTS compiler is run on a system that has the 
same byte ordering as the target system. Any 
SCRIPTS patching in memory must patch the 
instruction with the byte ordering that the 
SCRIPTS processor expects. 

Software drivers for the SYM53C895 should 
access registers by their logical name (i.e., 
SCNTLO) rather than by their address.The logical 
name should be equated to the register’s Big 
Endian address in Big Endian mode (SCNTLO = 
03h), and its Little Endian address in Little 
Endian Mode (SCNTLO = 00h).This way, there is 
no change to the software when moving from one 
mode to the other; only the equate statement set¬ 
ting the operating modes needs to be changed. 

Addressing of registers from within a SCRIPTS 
instruction is independent of bus mode. Internally, 
the SYM53C895 always operates in Little Endian 
mode* 
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Functional Description 

Loopback Mode 


Loopback Mode Parity Options 


The SYM53C895 loopback mode allows testing of 
both initiator and target functions and, in effect, 
lets the chip communicate with itself. When the 
Loopback Enable bit is set in the STESTl register, 
the SYM53C895 allows control of all SCSI sig¬ 
nals, whether the SYM53C895 is operating in ini¬ 
tiator or target mode. For more information on 
this mode of operation, refer to the Symbios Logic 
PCI-SCSI Programming Guide . 


The SYM53C895 implements a flexible parity 
scheme that allows control of the parity sense, 
allows parity checking to be turned on or off, and 
has the ability to deliberately send a byte with bad 
parity over the SCSI bus to test parity error recov¬ 
ery procedures. Table 2-4 defines the bits that are 
involved in parity control and observation. Table 
Table 2-5 describes the parity control function of 
the Enable Parity Checking and Assert SCSI Even 
Parity bits in the SCNTLO register. Table 2-6 
describes the options available when a parity error 
occurs. 


Table 2-4: Bits Used for Parity Control and Generation 


Bit Name 

Location 

Description 

Assert SATN/ on 
Parity Errors 

SCNTLO, Bit 1 

Causes the SYM53C895 to automatically assert SATN/ when it 
detects a parity error while operating as an initiator. 

Enable Parity 
Checking 

SCNTLO, Bit 3 

Enables the SYM53C895 to check for parity errors. The 
SYM53C895 checks for odd parity. 

Assert Even SCSI 
Parity 

SCNTL1, Bit 2 

Determines the SCSI parity sense generated by the 

SYM53C895 to the SCSI bus. 

Disable Halt on 
SATN/ or a Parity 
Error (Target Mode 
Only) 

SCNTL1, Bit 5 

Causes the SYM53C895 not to halt operations when a parity 
error is detected in target mode. 

Enable Parity Error 
Interrupt 

SIENO, Bit 0 

Determines whether the SYM53C895 will generate an interrupt 
when it detects a SCSI parity error. 

Parity Error 

SISTO, Bit 0 

This status bit is set whenever the SYM53C895 has detected a 
parity error on the SCSI bus. 

Status of SCSI 

Parity Signal 

SSTATO, Bit 0 

This status bit represents the active high current state of the 

SCSI SDPO parity signal. 

SCSI SDPl Signal 

SSTAT2, Bit 0 

This bit represents the active high current state of the SCSI 

SDPl parity signal. 

Latched SCSI Parity 

SSTAT 2, Bit 3 and 
SSTAT1, Bit 3 

These bits reflect the SCSI odd parity signal corresponding to 
the data latched into the SIDL register 

Master Parity Error 
Enable 

CTEST4, Bit 3 

Enables parity checking during master data phases. 

Master Data Parity 
Error 

DSTAT, Bit 6 

Set when the SYM53C895 as a master detects that a target 
device has signalled a parity error during a data phase. 

Master Data Parity 
Error Interrupt 

Enable 

DIEN, Bit 6 

By clearing this bit, a Master Data Parity Error will not cause 
IRQ/ to be asserted, but the status bit will be set in the DSTAT 
register. 


2-8 


SYM53C895 Data Manual 






Functional Description 

Parity Options 


Table 2-5? SCSI Parity Control 


EPC 

AESP 

Description 

0 

0 

Will not check for parity errors. Parity is generated when send¬ 
ing SCSI data. Asserts odd parity when sending SCSI data. 

0 

1 

Will not check for parity errors. Parity is generated when send¬ 
ing SCSI data. Asserts even parity when sending SCSI data. 

1 

0 

Checks for odd parity on SCSI data received. Parity is generated 
when sending SCSI data. Asserts odd parity when sending SCSI 
data. 

1 

1 

Checks for odd parity on SCSI data received. Parity is generated 
when sending SCSI data. Asserts even parity when sending 

SCSI data. 

Key: 
EPC = 
ASEP 

Enable Parity Checking (bit 3 SCNTLO) 

= Assert SCSI Even Parity (bit 2 SCNTL1) 


This table only applies when the Enable Parity Checking bit is set . 


Table 2-6: 

SCSI Parity Errors and Interrupts 

DHP 

PAR 

Description 

0 

0 

Will halt when a parity error occurs in target or initiator mode 
and will NOT generate an interrupt. 

0 

1 

Will halt when a parity error occurs in target mode and will gen¬ 
erate an interrupt in target or initiator mode. 

1 

0 

Will not halt in target mode when a parity error occurs until the 
end of the transfer. An interrupt will not be generated. 

1 

1 

Will not halt in target mode when a parity error occurs until the 
end of the transfer. An interrupt will be generated. 

Key: DHP = Disable Halt on SATN! or Parity Error 

(bit 5 SCNTL1J PAR — Parity Error (bit 0 SIENO) 
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Functional Description 

DMA FIFO 


DMA FIFO 

The DMA FIFO is 4 bytes wide and 28 or 204 
transfers deep. The DMA FIFO is illustrated in 
Figure 2-1. To assure compatibility with older 
products in the SYM53C8XX family, the user may 


set the DMA FIFO size to 112 bytes by clearing 
the DMA FIFO Size bit, bit 5 in the CTEST5 reg¬ 
ister. 

The 816-byte FIFO size is related to the 
SYM53C895 FIFO architecture. It does not 
reflect any specific system design parameters or 
expectations. 
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Figure 2-1: DMA FIFO Sections 


Data Paths 

The data path through the SYM53C895 is depen¬ 
dent on whether data is being moved into or out of 
the chip, and whether SCSI data is being trans¬ 
ferred asynchronously or synchronously. 

Figure 2-2 shows how data is moved to/from the 
SCSI bus in each of the different modes. 

The following steps determine if any bytes remain 
in the data path when the chip halts an operation: 

Asynchronous SCSI Send 

1. If the DMA FIFO size is set to 112 bytes, look 


at the DFIFO and DBC registers and calculate 
if there are bytes left in the DMA FIFO. To 
make this calculation, subtract the seven least 
significant bits of the DBC register from the 7- 
bit value of the DFIFO register. AND the 
result with 7Fh for a byte count between zero 
and 112. 

If the DMA FIFO size is set to 816 bytes 
(using bit 5 of the CTEST5 register), subtract 
the 10 least significant bits of the DBC register 
from the 10-bit value of the DMA FIFO Byte 
Offset Counter, which consists of bits 1-0 in 
the CTEST5 register and bits 7-0 of the DMA 
FIFO register. AND the result with 3FFh for a 
byte count between 0 and 816. 
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Functional Description 

DMA FIFO 


2. Read bit 5 in the SSTATO and SSTAT2 

registers to determine if any bytes are left in the 
SODL register. If bit 5 is set in the SSTATO or 
SSTAT2, then the least significant byte or the 
most significant byte in the SODL register is 
full, respectively. Checking this bit also reveals 
bytes left in the SODL register from a Chained 
Move operation with an odd byte count. 

Synchronous SCSI Send 

1. If the DMA FIFO size is set to 112 bytes, look 
at the DFIFO and DBC registers and calculate 
if there are bytes left in the DMA FIFO. To 
make this calculation, subtract the seven least 
significant bits of the DBC register from the 7- 
bit value of the DFIFO register. AND the 
result with 7Fh for a byte count between zero 
and 112. 

If the DMA FIFO size is set to 816 bytes 
(using bit 5 of the CTEST5 register), subtract 
the 10 least significant bits of the DBC register 
from the 10-bit value of the DMA FIFO Byte 
Offset Counter, which consists of bits 1-0 in 
the CTEST5 register and bits 7-0 of the DMA 
FIFO register. AND the result with 3FFh for a 
byte count between 0 and 816. 

2. Read bit 5 in the SSTATO and SSTAT2 
registers to determine if any bytes are left in the 
SODL register. If bit 5 is set in the SSTATO or 
SSTAT2, then the least significant byte or the 
most significant byte in the SODL register is 
full, respectively. Checking this bit also reveals 
bytes left in the SODL register from a Chained 
Move operation with an odd byte count. 

3. Read bit 6 in the SSTATO and SSTAT2 
registers to determine if any bytes are left in the 
SODR register. If bit 6 is set in the SSTATO or 
SSTAT2, then the least significant byte or the 
most significant byte in the SODR register is 
full, respectively. 


Asynchronous SCSI Receive 

1. If the DMA FIFO size is set to 112 bytes, look 
at the DFIFO and DBC registers and calculate 
if there are bytes left in the DMA FIFO. To 
make this calculation, subtract the seven least 
significant bits of the DBC register from the 7- 
bit value of the DFIFO register. AND the 
result with 7Fh for a byte count between 0 and 
112 . 

If the DMA FIFO size is set to 816 bytes 
(using bit 5 of the CTEST5 register), subtract 
the 10 least significant bits of the DBC register 
from the 10-bit value of the DMA FIFO Byte 
Offset Counter, which consists of bits 1-0 in 
the CTEST5 register and bits 7-0 of the DMA 
FIFO register. AND the result with 3FFh for a 
byte count between 0 and 816. 

2. Read bit 7 in the SSTATO and SSTAT2 
register to determine if any bytes are left in the 
SIDL register. If bit 7 is set in the SSTATO or 
SSTAT2, then the least significant byte or the 
most significant byte is full, respectively. 

3. If any wide transfers have been performed 
using the Chained Move instruction, read the 
Wide SCSI Receive bit (SCNTL2, bit 0) to 
determine whether a byte is left in the SWIDE 
register. 

Synchronous SCSI Receive 

1. If the DMA FIFO size is set to 112 bytes, 
subtract the seven least significant bits of the 
DBC register from the 7-bit value of the 
DFIFO register. AND the result with 7Fh for a 
byte count between 0 and 112. 

If the DMA FIFO size is set to 816 bytes 
(using bit 5 of the CTEST5 register), subtract 
the 10 least significant bits of the DBC register 
from the 10-bit value of the DMA FIFO Byte 
Offset Counter, which consists of bits 1-0 in 
the CTEST5 register and bits 7-0 of the DMA 
FIFO register. AND the result with 3FFh for a 
byte count between 0 and 816. 
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Functional Description 

SCSI Bus Interface 


2. Read bits 7-4 of the SSTAT1 register and bit 4 
of the SSTAT2 register, the binary 
representation of the number of valid bytes in 
the SCSI FIFO, to determine if any bytes are 
left in the SCSI FIFO. 

3. If any wide transfers have been performed 


using the Chained Move instruction, read the 
Wide SCSI Receive bit (SCNTL2, bit 0) to 
determine whether a byte is left in the SWIDE 
register. 



Figure 2-2: SYM53C895 Host Interface Data Paths 


SCSI Bus Interface 

The SYM53C895 performs single-ended and low 
voltage differential (LVD) transfers, and supports 
traditional (high-power) differential operation 
when the chip is connected to external high-power 
differential transceivers. 

To support LVD SCSI, all SCSI data and control 
signals have a positive and a negative signal line, as 
in high voltage differential. In single-ended and 
high voltage differential operation, the negative sig¬ 
nals perform the SCSI data and control function. 
In high voltage differential mode, the positive sig¬ 
nals provide directional control and in single- 
ended mode they are virtual ground drivers. 
TolerANT technology provides signal filtering at 
the inputs of SREQ/ and SACK/ to increase 
immunity to signal reflections. 


LVDlink Technology 

To support greater device connectivity and a 
longer SCSI cable, the SYM53C895 features 
LVDlink technology, the Symbios Logic imple¬ 
mentation of LVD SCSI. LVDlink transceivers 
provide the inherent reliability of differential SCSI, 
and a long-term migration path of faster SCSI 
transfer rates. 

LVDlink technology is based on current drive; its 
low output current reduces the power needed to 
drive the SCSI bus, so that the I/O drivers can be 
integrated directly onto the chip. This reduces the 
cost and complexity compared to traditional (high 
power) differential designs. LVDlink lowers the 
amplitude of noise reflections and allows higher 
transmission frequencies. 
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Functional Description 

SCSI Bus Interface 


The Symbios Logic LVDlink transceivers operate 
in LVD and single-ended modes. They allow the 
chip to detect a high voltage differential signal 
when the chip is connected to external high voltage 
differential transceivers.The SYM53C895 auto¬ 
matically detects which type of signal is connected, 
based on voltage detected by the DIFFSENS pin. 
Bits 7 and 6 of the STEST4 register contain the 
encoded value for the type of signal that is detected 
(LVD, single-ended, or high voltage differential). 
Please see the STEST4 register description for 
encoding and other bit information. 


High Voltage 
Differential Mode 

To maintain backward compatibility with legacy 
systems, the SYM53C895 can operate in high volt¬ 
age differential mode (when the chip is connected 
to external differential transceivers). In high volt¬ 
age differential mode, the SD+ (15-0), SDP+ (1- 
0), REQ+, ACK+, RST+, BSY+, and SEL+ sig¬ 
nals control the direction of external differential- 
pair transceivers.The SYM53C895 is placed in 
differential mode by setting the DIF bit, bit 5 of 
the STEST2 register (4Eh). Setting this bit tri¬ 
states the BSY-, SEL-, and RST- pads so they can 
be used as pure input pins. In addition to the stan¬ 
dard SCSI lines, the following signals are used by 
the SYM53C895 during high voltage differential 
operation: 


Signal 


Function 


BSY+, SEL+, Active high signals used to enable the differential drivers as outputs for SCSI signals BSY-, 

Rg-p + SEL-, and RST, respectively 

SD+(15-0), Active high signals used to control direction of the differential drivers for SCSI data and par- 

SD P+ (1 -0) ity lines, respectively 

ACK+ Active high signal used to control direction of the differential driver for initiator group sig¬ 

nals ATN- and ACK- 

REQ+ Active high signal used to control direction of the differential drivers for target group signals 

MSG-, C/D-, I/O- and REQ-/ 

DIFFSENS Input to die SYM53C895 used to detect the voltage level of a SCSI signal to determine 

whether it is a single-ended, LVD, or high-power differential signal. The result is displayed in 
STEST4 bits 7-6. 
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Functional Description 

SCSI Bus Interface 


In the example differential wiring diagram in Fig¬ 
ure 2-3, the SYM53C895 is connected to theTI 
SN75976 differential transceiver for Ultra SCSI 
operation. The recommended value of the pull-up 
resistor on the REQ-, ACK-, MSG-, C/D-, I/O-, 
ATN-, SD0-7-, and SDPO- lines is 680 12 when 
the Active Negation portion of Symbios Logic 
TolerANT technology is not enabled. When 
TolerANT is enabled, the recommended resistor 
value on the REQ-, ACK-, SD7-0-, and SDP0- 
signals is 1.5 KUThe electrical characteristics of 
these pins change when TolerANT is enabled, per¬ 
mitting a higher resistor value. 

To interface the SYM53C895 to the SN75976A, 
connect the positive pins in the SCSI LVD pair of 
the SYM53C895 directly to the transceiver 
enables (nDE/RE/). These signals control the 
direction of the channels on the SN75976A. 

The SCSI bidirectional control and data pins 
(SD7-0- SDP0-, REQ- ACK-, MSG-, I_0-, C_D, 
and ATN-) of the SYM53C895 connect to the 
bidirectional data pins (nA) of the SN75976A with 
a pull-up resistor. The pull-up value should be no 
lower than the transceiver Iql can tolerate, but not 
so high as to cause RC timing problems. The three 
remaining pins, SEL-, BSY- and RST, are con¬ 
nected to the SN75976A with a pull-down resistor. 
The pull-down resistors are required when the pins 
(nA) of the SN75976A are configured as inputs. 
When the data pins are inputs, the resistors pro¬ 
vide a bias voltage to both the SYM53C895 pins 
(SEL-, BSY-, and RST) and the SN75976A data 
pins. Because the SEL-, BSY-, and RST pins on 
the SYM53C895 are inputs only, this configura¬ 
tion allows for the SEL-, BSY-, and RST SCSI 
signals to be asserted on the SCSI bus. The differ¬ 
ential pairs on the SCSI bus are reversed when 
connected to the SN75976A, due to the active low 
nature of the SCSI bus. 


8-bit/16-bit SCSI and the high voltage 
differential interface 

In an 8-bit SCSI bus, the SD15-8 pins on the 
SYM53C895 should be pulled up with a 1.5 K12 
resistor or terminated like the rest of the SCSI bus 
lines. This is very important, as errors may occur 
during reselection if these lines are left floating. 
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Functional Description 

SCSI Bus Interface 


SCSI Termination 

The terminator networks provide the biasing 
needed to pull signals to an inactive voltage level* 
and to match the impedance seen at the end of the 
cable with the characteristic impedance of the 
cable.Terminators must be installed at the extreme 
ends of the SCSI chain* and only at the ends; no 
system should ever have more or less than two ter¬ 
minators installed and active. SCSI host adapters 
should provide a means of accommodating termi¬ 
nators. The terminators should be socketed* so 
that if not needed they may be removed* or there 
should be a means of disabling them with software. 

Single-ended cables can use a 220 12 pull-up to the 
terminator power supply (Term-Power) line and a 
330 12 pull-down to Ground. Because of the high- 
performance nature of the SYM53C895* Regu¬ 
lated (or Active) termination is recommended. 
Figure 2-4 shows a Unitrode active terminator. For 
additional information* refer to the SCSI-2 Speci¬ 
fication. TolerANT active negation can be used 
with either termination network. 

For information on terminators that support LVD* 
refer to the SPI-2 draft standard. 

Note: if the SYM53C895 is to be used in a design 
with only an 8-bit SCSI bus* all 16 data 
lines still must be terminated or pulled high 
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SCSI Bus Interface 
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DIFF SENSE connects to the SCSI bus Diffsense line to detect what type of devices (single-ended, LVD, 
or high-voltage differential) are connected to the SCSI bus. 

DISCNCT shuts down the terminator when it is not at the end of the bus. The disconnect pin low enables the terminator. 
*Use 1-2 additional UCC5630 terminators to connect the SCSI control signals and additional wide SCSI data byte as needed. 


Figure 2-4: Regulated Termination for Ultra2 SCSI 
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Functional Description 

Synchronous Operation 


(Re)Select During 
(Re) Selection 

In multi-threaded SCSI I/O environments, it is not 
uncommon to be selected or reselected while try¬ 
ing to perform selection/reselection.This situation 
may occur when a SCSI controller (operating in 
initiator mode) tries to select a target and is rese¬ 
lected by another. The Select SCRIPTS instruc¬ 
tion has an alternate address to which the 
SCRIPTS will jump when this situation occurs. 
The analogous situation for target devices is being 
selected while trying to perform a reselection. 

Once a change in operating mode occurs, the initi¬ 
ator SCRIPTS should start with a Set Initiator 
instruction or the target SCRIPTS should start 
with a Set Target instruction. The Selection and 
Reselection Enable bits (SCID bits 5 and 6, 
respectively) should both be asserted so that the 
SYM53C895 may respond as an initiator or as a 
target. If only selection is enabled, the 
SYM53C895 cannot be reselected as an initiator. 
There are also status and interrupt bits in the 
SISTO and SIENO registers, respectively, indicat¬ 
ing that the SYM53C895 has been selected (bit 5) 
and reselected (bit 4). 


Synchronous Operation 

The SYM53C895 can transfer synchronous SCSI 
data in both initiator and target modes. The 
SXFER register controls both the synchronous off¬ 
set and the transfer period. It may be loaded by the 
GPU before SCRIPTS execution begins, from 
within SCRIPTS via a Table Indirect I/O instruc¬ 
tion, or with a Read-Modify-Write instruction. 

The SYM53C895 can receive data from the SCSI 
bus at a synchronous transfer period as short as 25 
ns, regardless of the transfer period used to send 
data.The SYM53C895 can receive data at one- 
fourth of the divided SCLK frequency. Depending 
on the SCLK frequency, the negotiated transfer 
period, and the synchronous clock divider, the 
SYM53C895 can send synchronous data at inter¬ 
vals as short as 25 ns for Ultra2 SCSI, 50 ns for 
Ultra SCSI, 100 ns for fast SCSI and 200 ns for 
SCSI-1. 


Determining the 
Data Transfer Rate 

Synchronous data transfer rates are controlled by 
bits in two different registers of the SYM53C895. 
A brief description of the bits is provided below. 
Figure 2-5 illustrates the clock division factors 
used in each register, and the role of the register 
bits in determining the transfer rate. 

SCNTL3 Register, bits 6-4 (SCF2-0) 

The SCF2-0 bits select the factor by which the fre¬ 
quency of SCLK is divided before being presented 
to the synchronous SCSI control logic.The output 
from this divider controls the rate at which data 
can be received; this rate must not exceed 160 
MHz. The receive rate of synchronous SCSI data 
is 1/4 of the SCF divider output. For example, if 
SCLK is 160 MHz and the SCF value is set to 
divide by one, then the maximum rate at which 
data can be received is 40 MHz (160/(1*4) = 40). 
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Synchronous Operation 


SCNTL3 Register, bits 2-0 (CCF2-0) 

The CCF2-0 bits select the factor by which the 
frequency of SCLK is divided before being pre¬ 
sented to the asynchronous SCSI core logic. This 
divider must be set according to the input clock 
frequency in the table. 

SXFER Register, bits 7-5 (TP2-0) 

TheTP2-0 divider bits determine the SCSI syn¬ 
chronous transfer period when sending synchro¬ 
nous SCSI data in either initiator or target mode. 
This value further divides the output from the 
SCF divider. 


Ultra2 SCSI 

Synchronous Data Transfers 

Ultra2 SCSI is an extension of current Ultra SCSI 
synchronous transfer specifications. It allows syn¬ 
chronous transfer periods to be negotiated down as 
low as 25 ns, which is half the 50 ns period allowed 
under Ultra SCSI. This will allow a maximum 
transfer rate of 80 MB/s on a 16-bit, LVD SCSI 
bus. The SYM53C895 has a SCSI clock quadru¬ 
plet that must be enabled for the chip to perform 
Ultra2 SCSI transfers with a 40MHz oscillator. In 
addition, the following bit values affect the chip’s 
ability to support Ultra2 SCSI synchronous trans¬ 
fer rates: 

1. Clock Conversion Factor bits, SCNTL3 
register bits 2-0 and Synchronous Clock 
Conversion Factor bits, SCNTL3 register bits 
6-4. These fields support a value of 111 
(binary), allowing the 160 MHz SCLK 
frequency to be divided down by 8 for the 
asynchronous logic. 

2. Ultra2 SCSI Enable bit, SCNTL 3 register bit 
7. Setting this bit enables Ultra2 SCSI 
synchronous transfers in systems that use the 
internal SCSI clock quadrupler. 

3. TolerANT Enable bit, STEST3 register bit 7. 
Active negation must be enabled for the 
SYM53C895 to perform Ultra2 SCSI 
transfers. 

Note: the clock quadrupler requires a 40 MHz 
external clock. Symbios Logic software 
assumes that the SYM53C895 is 
connected to a 40 MHz external clock, 
which is quadrupled to achieve Ultra2 
SCSI transfer rates. 
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SCF 

Divisor 
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luadrupler 


QCLK 


CCF2 CCF1 CCFO QCLK (MHz) 

~0 0 0 50.1-66.00 

0 0 1 16.67-25.00 

0 1 0 25.01-37.50 

0 1 1 37.51-50.00 

1 0 0 50.01-66.00 
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Example: 

QCLK (Quadrupled SCSI Clock) = 160 MHz, SCF=1(/1), 
XFERP=0(/4), 

CCF=7 (/8) 

Synchronous send rate = (QCLK/SCF)/XFERP= 
(160/l)/4=40MB/s 

Synchronous receive rate=(QCLK/SCF)/4=(160/l)/4=40MB/s 


Figure 2-5: Determining the Synchronous Transfer Rate 
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Functional Description 

Interrupt Handling 


Interrupt Handling 

The SCRIPTS processor in the SYM53C895 per¬ 
forms most functions independently of the host 
microprocessor. However, certain interrupt situa¬ 
tions must be handled by the external micropro¬ 
cessor. This section explains all aspects of 
interrupts as they apply to the SYM53C895. 


Polling and 
Hardware Interrupts 

The external microprocessor is informed of an 
interrupt condition by polling or hardware inter¬ 
rupts. Polling means that the microprocessor must 
continually loop and read a register until it detects 
a bit set that indicates an interrupt. This method is 
the fastest, but it wastes CPU time that could be 
used for other system tasks.The preferred method 
of detecting interrupts in most systems is hardware 
interrupts. In this case, the SYM53C895 will 
assert the Interrupt Request (IRQ/) line that will 
interrupt the microprocessor, causing the micro¬ 
processor to execute an interrupt service routine. A 
hybrid approach would use hardware interrupts for 
long waits, and use polling for short waits. 


Registers 

The registers in the SYM53C895 that are used for 
detecting or defining interrupts are the ISTAT, 
SISTO, SIST1, DSTAT, SIENO, SIEN1, 

DCNTL, and DIEN. 

ISTAT 

The ISTAT is the only register that can be 
accessed as a slave during SCRIPTS operation, 
therefore it is the register that is polled when 
polled interrupts are used. It is also the first regis¬ 
ter that should be read when the IRQ/ pin has been 
asserted in association with a hardware interrupt. 
The INTF (Interrupt on the Fly) bit should be the 
first interrupt serviced. It must be written to one to 
be cleared. This interrupt must be cleared before 
servicing any other interrupts. If the SIP bit in the 


ISTAT register is set, then a SCSI-type interrupt 
has occurred and the SISTO and SIST1 registers 
should be read. If the DIP bit in the ISTAT regis¬ 
ter is set, then a DMA-type interrupt has occurred 
and the DSTAT register should be read. SCSI- 
type and DMA-type interrupts may occur simulta¬ 
neously, so in some cases both SIP and DIP may 
be set. 

SISTO and SIST1 

The SISTO and SIST1 registers contain the SCSI- 
type interrupt bits. Reading these registers will 
determine which condition or conditions caused 
the SCSI-type interrupt, and will clear that SCSI 
interrupt condition. If the SYM53C895 is receiv¬ 
ing data from the SCSI bus and a fatal interrupt 
condition occurs, the SYM53C895 will attempt to 
send the contents of the DMA FIFO to memory 
before generating the interrupt. If the 
SYM53C895 is sending data to the SCSI bus and 
a fatal SCSI interrupt condition occurs, data could 
be left in the DMA FIFO. Because of this the 
DMA FIFO Empty (DFE) bit in DSTAT should 
be checked. If this bit is clear, set the CLF (Clear 
DMA FIFO) and CSF (Clear SCSI FIFO) bits 
before continuing. The CLF bit is bit 2 in 
CTEST3.The CSF bit is bit 1 in STEST3. 

DSTAT 

The DSTAT register contains the DMA-type 
interrupt bits. Reading this register will determine 
which condition or conditions caused the DMA- 
type interrupt, and will clear that DMA interrupt 
condition. Bit 7 in DSTAT, DFE, is purely a status 
bit; it will not generate an interrupt under any cir¬ 
cumstances and will not be cleared when read. 
DMA interrupts will flush neither the DMA nor 
SCSI FIFOs before generating the interrupt, so 
the DFE bit in the DSTAT register should be 
checked after any DMA interrupt. If the DFE bit 
is clear, then the FIFOs must be cleared by setting 
the CLF (Clear DMA FIFO) and CSF (Clear 
SCSI FIFO) bits, or flushed by setting the FLF 
(Flush DMA FIFO) bit. 
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SIENO and SIEN1 

The SIENO and SIENl registers are the interrupt 
enable registers for the SCSI interrupts in SISTO 
and SIST1. 

DIEN 

The DIEN register is the interrupt enable register 
for DMA interrupts in DSTAT. 

DCNTL 

When bit 1 in this register is set, the IRQ/ pin will 
not be asserted when an interrupt condition 
occurs. The interrupt is not lost or ignored, but 
merely masked at the pin. Clearing this bit when 
an interrupt is pending will immediately cause the 
IRQ/ pin to assert. As with any register other than 
ISTAT, this register cannot be accessed except by a 
SCRIPTS instruction during SCRIPTS execution. 


Fatal vs. Non-Fatal 
Interrupts 

A fatal interrupt, as the name implies, always 
causes SCRIPTS to stop running. All non-fatal 
interrupts become fatal when they are enabled by 
setting the appropriate interrupt enable bit. Inter¬ 
rupt masking will be discussed later in this section. 
All DMA interrupts (indicated by the DIP bit in 
ISTAT and one or more bits in DSTAT being set) 
are fatal. 

Some SCSI interrupts (indicated by the SIP bit in 
the ISTAT and one or more bits in SISTO or 
SISTl being set) are non-fatal. When the 
SYM53C895 is operating in Initiator mode, only 
the Function Complete (CMP), Selected (SEL), 
Reselected (RSL), General Purpose Timer Expired 
(GEN), and Handshake to Handshake Timer 
Expired (HTH) interrupts are non-fatal. When 
operating in Target mode CMP, SEL, RSL, Target 
mode: SATN/ active (M/A), GEN, and HTH are 
non-fatal. Refer to the description for the Disable 
Halt on a Parity Error or SATN/ active (Target 
Mode Only) (DHP) bit in the SCNTLl register to 
configure the chip’s behavior when the SATN/ 


interrupt is enabled during Target mode operation. 
The Interrupt on the Fly interrupt is also non- 
fatal, since SCRIPTS can continue when it occurs. 

The reason for non-fatal interrupts is to prevent 
SCRIPTS from stopping when an interrupt occurs 
that does not require service from the CPU. This 
prevents an interrupt when arbitration is complete 
(CMP set), when the SYM53C895 has been 
selected or reselected (SEL or RSL set), when the 
initiator has asserted ATN (target mode: SATN/ 
active), or when the General Purpose or Hand¬ 
shake to Handshake timers expire. These inter¬ 
rupts are not needed for events that occur during 
high-level SCRIPTS operation. 


Masking 

Masking an interrupt means disabling or ignoring 
that interrupt. Interrupts can be masked by clear¬ 
ing bits in the SIENO and SIENl (for SCSI inter¬ 
rupts) registers or DIEN (for DMA interrupts) 
register. How the chip will respond to masked 
interrupts depends on: whether polling or hard¬ 
ware interrupts are being used; whether the inter¬ 
rupt is fatal or non-fatal; and whether the chip is 
operating in Initiator or Target mode. 

If a non-fatal interrupt is masked and that condi¬ 
tion occurs, SCRIPTS will not stop, the appropri¬ 
ate bit in the SISTO or SISTl will still be set, the 
SIP bit in the ISTAT will not be set, and the IRQ/ 
pin will not be asserted. See the section on non- 
fatal vs. fatal interrupts for a list of the non-fatal 
interrupts. 

If a fatal interrupt is masked and that condition 
occurs, then SCRIPTS will still stop, the appropri¬ 
ate bit in the DSTAT, SISTO, or SISTl register 
will be set, and the SIP or DIP bits in the ISTAT 
will be set, but the IRQ/ pin will not be asserted. 

When the chip is initialized, enable all fatal inter¬ 
rupts if you are using hardware interrupts. If a fatal 
interrupt is disabled and that interrupt condition 
occurs, SCRIPTS will halt and the system will 
never know it unless it times out and checks the 
ISTAT after a certain period of inactivity. 
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If you are polling the ISTAT instead of using hard¬ 
ware interrupts, then masking a fatal interrupt will 
make no difference since the SIP and DIP bits in 
the ISTAT inform the system of interrupts, not the 
IRQ/ pin. 

Masking an interrupt after IRQ/ is asserted will not 
cause IRQ/ to be deasserted. 


Stacked Interrupts 

The SYM53C895 stacks interrupts if they occur 
one after the other. If the SIP or DIP bits in the 
ISTAT register are set (first level), then there is 
already at least one pending interrupt, and any 
future interrupts will be stacked in extra registers 
behind the SISTO, SIST1, and DSTAT registers 
(second level). When two interrupts have occurred 
and the two levels of the stack are full, any further 
interrupts will set additional bits in the extra regis¬ 
ters behind SISTO, SISTl, and DSTAT. When the 
first level of interrupts are cleared, all the inter¬ 
rupts that came in afterward will move into the 
SISTO, SISTl, and DSTAT. After the first inter¬ 
rupt is cleared by reading the appropriate register, 
the IRQ/ pin will be deasserted for a minimum of 
three CLKs; the stacked interrupt(s) will move 
into the SISTO, SISTl, or DSTAT; and the IRQ/ 
pin will be asserted once again. 

Since a masked non-fatal interrupt will not set the 
SIP or DIP bits, interrupt stacking will not occur. 
A masked, non-fatal interrupt will still post the 
interrupt in SISTO, but will not assert the IRQ/ 
pin. Since no interrupt is generated, future inter¬ 
rupts will move right into the SISTO or SISTl 
instead of being stacked behind another interrupt. 
When another condition occurs that generates an 
interrupt, the bit corresponding to the earlier 
masked non-fatal interrupt will still be set. 

A related situation to interrupt stacking is when 
two interrupts occur simultaneously. Since stack¬ 
ing does not occur until the SIP or DIP bits are 
set, there is a small timing window in which multi¬ 
ple interrupts can occur but will not be stacked. 
These could be multiple SCSI interrupts (SIP set), 
multiple DMA interrupts (DIP set), or multiple 
SCSI and multiple DMA interrupts (both SIP and 
DIP set). 


As previously mentioned, DMA interrupts will not 
attempt to flush the FIFOs before generating the 
interrupt. It is important to set either the Clear 
DMA FIFO (CLF) and Clear SCSI FIFO (CSF) 
bits if a DMA interrupt occurs and the DMA 
FIFO Empty (DFE) bit is not set. This is because 
any future SCSI interrupts will not be posted until 
the DMA FIFO is clear of data. These ‘locked out’ 
SCSI interrupts will be posted as soon as the 
DMA FIFO is empty. 


Halting in an 
Orderly Fashion 

When an interrupt occurs, the SYM53C895 will 

attempt to halt in an orderly fashion. 

■ If the interrupt occurs in the middle of an 
instruction fetch, the fetch will be completed, 
except in the case of a Bus Fault. Execution 
will not begin, but the DSP will point to the 
next instruction since it is updated when the 
current instruction is fetched. 

■ If the DMA direction is a write to memory and 
a SCSI interrupt occurs, the SYM53C895 will 
attempt to flush the DMA FIFO to memory 
before halting. Under any other circumstances 
only the current cycle will be completed before 
halting, so the DFE bit in DSTAT should be 
checked to see if any data remains in the DMA 
FIFO. 

■ SCSI SREQ/SACK handshakes that have 
begun will be completed before halting. 

■ The SYM53C895 will attempt to clean up any 
outstanding synchronous offset before halting. 

■ In the case of Transfer Control Instructions, 
once instruction execution begins it will 
continue to completion before halting. 

■ If the instruction is a JUMP/C ALL WHEN/IF 
<phase>, the DSP will be updated to the 
transfer address before halting. 

■ All other instructions may halt before 
completion. 
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Sample Interrupt 
Service Routine 

The following is a sample of an interrupt service 
routine for the SYM53C895. It can be repeated if 
polling is used, or should be called when the IRQ/ 
pin is asserted if hardware interrupts are used. 

1. Read ISTAT. 

2. If the INTF bit is set, it must be written to a 
one to clear this status. 

3. If only the SIP bit is set, read SISTO and 
SIST1 to clear the SCSI interrupt condition 
and get the SCSI interrupt status. The bits in 
the SISTO and SIST1 tell which SCSI 
interrupt(s) occurred and determine what 
action is required to service the interrupt(s). 

4. If only the DIP bit is set, read the DSTAT to 
clear the interrupt condition and get the DMA 
interrupt status. The bits in the DSTAT will 
tell which DMA interrupt(s) occurred and 
determine what action is required to service 
the interrupt (s). 

5. If both the SIP and DIP bits are set, read 
SISTO, SIST1, and DSTAT to clear the SCSI 
and DMA interrupt condition and get the 
interrupt status. If using 8-bit reads of the 
SISTO, SISTl, and DSTAT registers to clear 
interrupts, insert a 12 CLK delay between the 
consecutive reads to ensure that the interrupts 
clear properly. Both the SCSI and DMA 
interrupt conditions should be handled before 
leaving the ISR. It is recommended that the 
DMA interrupt be serviced before the SCSI 
interrupt, because a serious DMA interrupt 
condition could influence how the SCSI 
interrupt is acted upon. 

6. When using polled interrupts, go back to step 
1 before leaving the interrupt service routine, 
in case any stacked interrupts moved in when 
the first interrupt was cleared. When using 
hardware interrupts, the IRQ/ pin will be 
asserted again if there are any stacked 
interrupts. This should cause the system to re¬ 
enter the interrupt service routine. 
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Chained Block Moves 

Since the SYM53C895 has the capability to trans¬ 
fer 16- bit wide SCSI data, a unique situation 
occurs when dealing with odd bytes. The chained 
move (CHMOV) SCRIPTS instruction along with 
the Wide SCSI Send (WSS) and Wide SCSI 
Receive (WSR) bits in the SCNTL2 register are 
used to facilitate these situations. The Chained 
Block Move instruction is illustrated in Figure 2-6. 


Wide SCSI Send 
Bit 

The WSS bit is set whenever the SCSI core is 
sending data (Data Out for initiator or Data In for 
target) and the core detects a partial transfer at the 
end of a chained Block Move SCRIPTS instruc¬ 
tion (this flag will not be set if a normal Block 
Move instruction is used). Under this condition, 
the SCSI core does not send the low-order byte of 
the last partial memory transfer across the SCSI 
bus. Instead, the low-order byte is temporarily 
stored in the lower byte of the SODL register and 
the WSS flag is set. The hardware uses the WSS 
flag to determine what behavior must occur at the 
start of the next data send transfer. When the WSS 
flag is set at the start of the next transfer, the first 
byte (the high-order byte) of the next data send 
transfer is “married” with the stored low-order 
byte in the SODL register; and the two bytes are 
sent out across the bus, regardless of the type of 
Block Move instruction (normal or chained).The 
flag is automatically cleared when the “married” 
word is sent.The flag can alternately be cleared 
through SCRIPTS or by the microprocessor. 
Additionally, this bit can be used by the micropro¬ 
cessor or SCRIPTS for error detection and recov¬ 
ery purposes. 
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Wide SCSI Receive 
Bit 

The WSR bit is set whenever the SCSI core is 
receiving data (Data In for initiator or Data Out 
for target) and the core detects a partial transfer at 
the end of a block move or chained block move 
SCRIPTS instruction. When WSR is set, the high 
order byte of the last SCSI bus transfer is not 
transferred to memory. Instead, the byte is tempo¬ 
rarily stored in the SWIDE register. The hardware 
uses the WSR bit to determine what behavior must 
occur at the start of the next data receive transfer. 
The bit is automatically cleared at the start of the 
next data receive transfer. The bit can alternatively 
be cleared by the microprocessor or through 
SCRIPTS. The bit can also be used by the micro¬ 
processor or SCRIPTS for error detection and 
recovery purposes. 


SWIDE Register 

This register is used to store data for partial byte 
data transfers. For receive data, the SWIDE regis¬ 
ter holds the high-order byte of a partial SCSI 
transfer which has not yet been transferred to 
memory. This stored data may be a residue byte 
(and therefore ignored) or it may be valid data that 
will be transferred to memory at the beginning of 
the next Block Move instruction. 


SODL Register 

For send data, the low-order byte of the SODL 
register holds the low-order byte of a partial mem¬ 
ory transfer which has not yet been transferred 
across the SCSI bus.This stored data is usually 
“married” with the first byte of the next data send 
transfer, and both bytes are sent across the SCSI 
bus at the start of the next data send block move 
command. 


Chained Block Move 
SCRIPTS Instruction 

A chained Block Move SCRIPTS instruction is 
primarily used to transfer consecutive data send or 
data receive blocks. Using the chained block move 
instruction facilitates partial receive transfers and 
allows correct partial send behavior without addi¬ 
tional op code overhead. Behavior of the chained 
Block Move instruction varies slightly for sending 
and receiving data. 

For receive data (Data In for initiator or Data Out 
for target), a chained Block Move instruction indi¬ 
cates that if a partial transfer occurred at the end of 
the instruction, the WSR flag is set.The high order 
byte of the last SCSI transfer is stored in the 
SWIDE register rather than transferred to mem¬ 
ory. The contents of the SWIDE register should be 
the first byte transferred to memory at the start of 
the chained block move data stream. Since the 
byte count always represents data transfers to/ffom 
memory (as opposed to the SCSI bus), the byte 
transferred out of the SWIDE register is one of the 
bytes in the byte count. If the WSR bit is clear 
when a receive data chained Block Move instruc¬ 
tion is executed, the data transfer occurs similar to 
that of the regular block move instruction. Whether 
the WSR bit is set or clear, when a normal block 
move instruction is executed, the contents of the 
SWIDE register will be ignored and the transfer 
takes place normally. For “N” consecutive wide 
data receive Block Move instructions, the 2nd 
through the Nth Block Move instructions should 
be chained block moves. 

For send data (Data Out for initiator or Data In for 
target), a chained Block Move instruction indicates 
that if a partial transfer terminates the chained 
block move instruction, the last low-order byte 
(the partial memory transfer) should be stored in 
the lower byte of the SODL register and not sent 
across the SCSI bus. Without the chained block 
move instruction, the last low-order byte would be 
sent across the SCSI bus. The starting byte count 
represents data bytes transferred from memory but 
not to the SCSI bus when a partial transfer exists. 
For example, if the instruction is an Initiator 
chained Block Move Data Out of five bytes (and 
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WSS is not previously set), five bytes will be trans¬ 
ferred out of memory to the SCSI core, four bytes 
will be transferred from the SCSI core across the 
SCSI bus, and one byte will be temporarily stored 
in the lower byte of the SODL register waiting to 
be married with the first byte of the next block 
move instruction. Regardless of whether a chained 
Block Move or normal Block Move instruction is 
used, if the WSS bit is set at the start of a data send 
command, the first byte of the data send command 


is assumed to be the high-order byte and is “mar¬ 
ried” with the low-order byte stored in the stored 
in the lower byte of the SODL register before the 
two bytes are sent across the SCSI bus. For “N” 
consecutive wide data send Block Move com¬ 
mands, the first through the (Nth - 1) Block Move 
instructions should be Chained Block Moves. 


00 

04 

08 

0C 

10 


16 Bits ►! 

Notes: CHMOV 5,3 when DATA_OUT: Moves five bytes from address 03 in the host memory to the SCSI bus (bytes 03, 

04, 05, and 06 are moved and byte 07 remains in'the low order byte of the 
SCSI Output Data Latch register and is married with the first byte of the fol¬ 
lowing MOVE instruction). 

MOVE 5, 9 when DATA_OUT: _ Moves five bytes from address 09 in the host memory to the SCSI bus. _ 

Figure 2-6: Block Move and Chained Block Move Instructions 
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Chapter 3 

PCI Functional Description 


PCI Addressing 

There are three types of PCI-defined address 
space: 

■ Configuration space 

■ Memory space 

■ I/O space 

Configuration space is a contiguous 256 x 8-bit set 
of addresses dedicated to each “slot” or “stub” on 
the bus. Decoding C_BE/(3-0) determines if a PCI 
cycle is intended to access configuration register 
space. The IDSEL bus signal is a “chip select” that 
allows access to the configuration register space 
only. A configuration read/write cycle without 
IDSEL will be ignored. The eight lower order 
addresses are used to select a specific 8-bit register. 
AD(10-8) are decoded as well, but they must be 
zero or the SYM53C895 will not respond. Accord¬ 
ing to the PCI specification, AD(10-8) are to be 
used for multifunction devices. The host processor 
uses the PCI configuration space to initialize the 
SYM53C895. 

The lower 128 bytes of the SYM53C895 configu¬ 
ration space holds system parameters while the 
upper 128 bytes map into the SYM53C895 oper¬ 
ating registers. For all PCI cycles except configura¬ 
tion cycles, the SYM53C895 registers are located 
on the 256-byte block boundary defined by the 
base address assigned through the configured reg¬ 
ister. The SYM53C895 operating registers are 
available in both the upper and lower 128-byte 
portions of the 256-byte space selected. 

At initialization time, each PCI device is assigned a 
base address (in the case of the SYM53C895, the 
upper 24 bits of the address are selected) for mem¬ 


ory accesses and I/O accesses. On every access, the 
SYM53C895 compares its assigned base addresses 
with the value on the Address/Data bus during the 
PCI address phase. If there is a match of the upper 
24 bits, the access is for the SYM53C895 and the 
low order eight bits define the register to be 
accessed. A decode of C_BE/ (3-0) determines 
which registers and what type of access is to be 
performed. 

PCI defines memory space as a contiguous 32-bit 
memory address that is shared by all system 
resources, including the SYM53C895. Base 
Address Register One determines which 256-byte 
memory area this device will occupy. 

PCI defines I/O space as a contiguous 32-bit I/O 
address that is shared by all system resources, 
including the SYM53C895. Base Address Register 
Zero determines which 256-byte I/O area this 
device will occupy. 

PCI Bus Commands and 
Functions Supported 

Bus commands indicate to the target the type of 
transaction the master is requesting. Bus com¬ 
mands are encoded on the C_BE/(3-0) lines dur¬ 
ing the address phase. PCI bus command 
encoding and types appear in Table 3-1. 

The I/O Read command is used to read data from 
an agent mapped in I/O address space. All 32 
address bits are decoded. 

The I/O Write command is used to write data to an 
agent when mapped in I/O address space. All 32 
address bits are decoded. 
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The Memory Read, Memory Read Multiple, and 
Memory Read Line commands are used to read 
data from an agent mapped in memory address 
space. All 32 address bits are decoded. 


The Memory Write and Memory Write and Invali¬ 
date commands are used to write data to an agent 
when mapped in memory address space. All 32 
address bits are decoded. 



Table 3-1 s 

PCI Bus Commands Supported 


C_BE(3-0) 

Command Type 

Supported as Master 


Supported as Slave 

0000 

Special Interrupt Acknowledge 

No 


No 

0001 

Special Cycle 

No ^ 


No 

0010 

I/O Read Cycle 

Yes 


Yes 

0011 

I/O Write Cycle 

Yes 


Yes 

0100 

Reserved 


n/a 


0101 

Reserved 


n/a 


0110 

Memory Read 

Yes 


Yes 

0111 

Memory Write 

Yes 


Yes 

1000 

Reserved 


n/a 


1001 

Reserved 


n/a 


1010 

Configuration Read 

No 


Yes 

1011 

Configuration Write 

No 


Yes 

1100 

Memory Read Multiple 

Yes** 


No (defaults to 0110) 

1101 

Dual Address Cycle 

No 


No 

1110 

Memory Read Line 

Yes* 


No (defaults to 0110) 

mi 

Memory Write and Invalidate 

Yes*** 


No (defaults to 0111) 


* This operation is selectable by bit 3 in the DMODE operating register 
** This operation is selectable by bit 2 in the DMODE operating register 
***This operation is selectable by bit 0 in the GTE ST3 operating register 


PCI Cache Mode 

The SYM53C895 supports the PCI specification 
for an 8-bit Cache Line Size register located in 
PCI configuration space. The Cache Line Size reg¬ 
ister provides the ability to sense and react to non- 
aligned addresses corresponding to cache line 
boundaries. In conjunction with the Cache Line 
Size register, the PCI commands Read Line, Read 
Multiple, and Write and Invalidate are each soft¬ 
ware enabled or disabled to allow the user full flex¬ 
ibility in using these commands. 


Support for PCI 
Cache Line Size Register 

The SYM53C895 supports the PCI specification 
for an 8-bit Cache Line Size register in PCI config¬ 
uration space; it can sense and react to non-aligned 
addresses corresponding to cache line boundaries. 


Selection of Cache 
Line Size 

The cache logic will select a cache line size based 
on the values for the burst size in the DMODE 
register, bit 2 in the CTEST5 register, and the 
PCI Cache Line Size register. 
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Note: the SYM53C895 will not automatically use 
the value in the PCI Cache Line Size 
register as the cache line size value. The 
chip scales the value of the Cache Line Size 
register down to the nearest binary burst 
size allowed by the chip (2, 4, 8, 16, 32, 64, 
or 128), compares this value to the burst 
size defined by the values of the DMODE 
register and bit 2 of the CTEST5 register, 
then selects the smallest as the value for the 
cache line size. The SYM53C895 will use 
this value for all burst data transfers. 


Alignment 

The SYM53C895 uses the calculated line size 
value to monitor the current address for alignment 
to the cache line size. When it is not aligned, the 
chip attempts to align to the cache boundary by 
using a “smart aligning” scheme. This means that 
it will attempt to use the largest burst size possible 
that is less than the cache line size, to reach the 
cache boundary quickly with no overflow. This 
process is a stepping mechanism that will step up 
to the highest possible burst size based on the cur¬ 
rent address. 

The stepping process begins at a 4-dword bound¬ 
ary. The SYM53C895 will first try to align to a 4- 
dword boundary (0x0000, 0x0008, 0x0010, etc.) 
by using single dword transfers (no bursting). 

Once this boundary has been reached the chip will 
evaluate the current alignment to various burst 
sizes allowed, and will select the largest possible as 
the next burst size, while not exceeding the cache 
line size.The chip will then issue this burst, and re¬ 
evaluate the alignment to various burst sizes, again 
selecting the largest possible while not exceeding 
the cache line size, as the next burst size. This step¬ 
ping process continues until the chip reaches the 
cache line size boundary or runs out of data. Once 
a cache line boundary is reached, the chip will use 
the cache line size as the burst size from then on, 
except in the case of multiples (explained below). 
The alignment process is finished at this point. 


Example: Cache Line Size - 16, 

Current Address = 0x01 

The chip is not aligned to a 4-dword cache bound¬ 
ary (the stepping threshold), so it issues four sin- 
gle-dword transfers (the first is a 3-byte transfer). 
At address 0x10, the chip is aligned to a 4-dword 
boundary, but not aligned to any higher burst size 
boundaries that are less than the cache line size. 
So, the SYM53C895 will issue a burst of 4. At this 
point, the address is 0x20, and the chip will evalu¬ 
ate that it is aligned not only to a 4-dword bound¬ 
ary, but also to an 8-dword boundary. It will select 
the highest, 8, and burst 8 dwords. At this point, 
the address is 0x40, which is a cache line size 
boundary. Alignment stops, and the burst size 
from then on is switched to 16. 


Memory Move 
Misalignment 

The SYM53C895 will not operate in a cache 
alignment mode when a Memory Move instruc¬ 
tion type is issued and the read and write addresses 
are different distances from the nearest cache line 
boundary. For example, if the read address is 
0x2IF and the write address is 0x42F, and the 
cache line size is eight (8), the addresses are byte 
aligned, but they are not the same distance from 
the nearest cache boundary. The read address is 1 
byte from the cache boundary 0x220 and the write 
address is 17 bytes from the cache boundary 
0x440. In this situation, the chip will not align to 
cache boundaries and will operate as an 
SYM53C825. 


Memory Write 

and Invalidate Command 

The Memory Write and Invalidate command is 
identical to the Memory Write command, except 
that it additionally guarantees a minimum transfer 
of one complete cache line; i.e., the master intends 
to write all bytes within the addressed cache line in 
a single PCI transaction unless interrupted by the 
target. This command requires implementation of 
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the PCI Cache Line Size register at address OCh in 
PCI configuration space. The SYM53C895 
enables Memory Write and Invalidate cycles when 
bit 0 in the CTEST3 register (WRIE) and bit 4 in 
the PCI Command register are set. This will cause 
Memory Write and Invalidate commands to be 
issued when the following conditions are met: 

1. The CLSE bit, WRIE bit, and PCI 
configuration Command register, bit 4 must be 
set. 

2. The cache line size register must contain a 
legal burst size (2, 4, 8, 16, 32, 64, or 128) 
value AND that value must be less than or 
equal to the DMODE burst size. 

3. The chip must have enough bytes in the DMA 
FIFO to complete at least one full cache line 
burst. 

4. The chip must be aligned to a cache line 
boundary. 

When these conditions have been met, the 
SYM53C895 will issue a Write and Invalidate 
command instead of a Memory Write command 
during all PCI write cycles. 

Multiple Cache Line Transfers 

The Write and Invalidate command can write mul¬ 
tiple cache lines of data in a single bus ownership. 
The chip issues a burst transfer as soon as it 
reaches a cache line boundary. The size of the 
transfer will not automatically be the cache line 
size, but rather a multiple of the cache line size as 
allowed for in the Revision 2.1 of the PCI specifi¬ 
cation. The logic will select the largest multiple of 
the cache line size based on the amount of data to 
transfer, with the maximum allowable burst size 
being that determined from the DMODE Burst 
Size bits and CTEST 5, bit 2. If multiple cache 
line size transfers are not desired, the DMODE 
burst size can be set to exactly the cache line size 
and the chip will only issue single cache line trans¬ 
fers. 


After each data transfer, the chip re-evaluates the 
burst size based on the amount of remaining data 
to transfer and again selects the highest possible 
multiple of the cache line size, no larger than the 
DMODE burst size. The most likely scenario of 
this scheme is that the chip will select the 
DMODE burst size after alignment, and issue 
bursts of this size. The burst size will, in effect, 
throttle down toward the end of a long Memory 
Move or Block Move transfer until only the cache 
line size burst size is left; the chip will finish the 
transfer with this burst size. 

Latency 

In accordance with the PCI specification, the 
chip's latency timer will be ignored when issuing a 
Write and Invalidate command such that when a 
latency time-out has occurred, the SYM53C895 
will continue to transfer up until a cache line 
boundary. At that point, the chip will relinquish 
the bus and finish the transfer at a later time using 
another bus ownership. If the chip is transferring 
multiple cache lines it will continue to transfer 
until the next cache boundary is reached. 

PCI Target Retry 

During a Write and Invalidate transfer, if the target 
device issues a retry (STOP with no TRDY, indi¬ 
cating that no data was transferred), the 
SYM53C895 will relinquish the bus and immedi¬ 
ately try to finish the transfer on another bus own¬ 
ership. The chip will issue another Write and 
Invalidate command on the next ownership, in 
accordance with the PCI specification. 

PCI Target Disconnect 

During a Write and Invalidate transfer, if the target 
device issues a disconnect the SYM53C895 will 
relinquish the bus and immediately try to finish the 
transfer on another bus ownership. The chip will 
not issue another Write and Invalidate command 
on the next ownership unless the address is 
aligned. 
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Memory Read 
Line Command 

This command is identical to the Memory Read 
command, except that it additionally indicates that 
the master intends to fetch a complete cache line. 
This command is intended to be used with bulk 
sequential data transfers where the memory system 
and the requesting master might gain some perfor¬ 
mance advantage by reading up to a cache line 
boundary rather than a single memory cycle.The 
Read Line Mode function that exists in the previ¬ 
ous SYM53C8XX chips has been modified in the 
SYM53C895 to reflect the PCI Cache Line Size 
register specifications. The functionality of the 
Enable Read Line bit (bit 3 in DMODE) has been 
modified to more resemble the Write and Invali¬ 
date mode in terms of conditions that must be met 
before a Read Line command will be issued. How¬ 
ever, the Read Line option will operate exactly like 
the previous SYM53C8XX chips when cache 
mode has been disabled by a CLSE bit reset or 
when certain conditions exist in the chip 
(explained below). 

The Read Line mode is enabled by setting bit 3 in 
the DMODE register. If cache mode is disabled, 
Read Line commands will be issued on every read 
data transfer, except op code fetches, as in previ¬ 
ous SYM53C8XX chips. 

If cache mode has been enabled, a Read Line com¬ 
mand will be issued on all read cycles, except op 
code fetches, when the following conditions have 
been met: 

1. The CLSE and Enable Read Line bits must be 
set. 

2. The Cache Line Size register must contain a 
legal burst size value (2,4, 8, 16, 32, 64, or 
128) AND that value must be less than or 
equal to the DMODE burst size. 

3. The number of bytes to be transferred at the 
time a cache boundary has been reached must 
be equal to or greater than the DMODE burst 
size. 


4. The chip must be aligned to a cache line 
boundary. 

When these conditions have been met, the chip 
will issue a Read Line command instead of a 
Memory Read during all PCI read cycles. Other¬ 
wise, it will issue a normal Memory Read com¬ 
mand. 


Memory Read 
Multiple Command 

This command is identical to the Memory Read 
command except that it additionally indicates that 
the master may intend to fetch more than one 
cache line before disconnecting.The SYM53C895 
supports PCI Read Multiple functionality and will 
issue Read Multiple commands on the PCI bus 
when the Read Multiple Mode is enabled. This 
mode is enabled by setting bit 2 of the DMODE 
register (ERMP). If cache mode has been enabled, 
a Read Multiple command will be issued on all 
read cycles, except op code fetches, when the fol¬ 
lowing conditions have been met: 

1. The CLSE and ERMP bits must be set. 

2. The Cache Line Size register must contain a 
legal burst size value (2, 4, 8, 16, 32, 64, or 

128) AND that value must be less than or 
equal to the DMODE burst size. 

3. The number of bytes to be transferred at the 
time a cache boundary has been reached must 
be at least twice the full cache line size. 

4. The chip must be aligned to a cache line 
boundary. 

When these conditions have been met, the chip 
will issue a Read Multiple command instead of a 
Memory Read during all PCI read cycles. 

Burst Size Selection 

The Read Multiple command reads in multiple 
cache lines of data in a single bus ownership. The 
number of cache lines to be read is a multiple of 
the cache line size as allowed for in the Revision 
2.1 of the PCI specification. The logic will select 
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the largest multiple of the cache line size based on 
the amount of data to transfer, with the maximum 
allowable burst size being that determined from 
the DMODE Burst Size bits and CTEST 5, bit 2. 

Read Multiple with Read Line Enabled 

When both the Read Multiple and Read Line 
modes have been enabled, the Read Line com¬ 
mand will not be issued if the above conditions are 
met. Instead, a Read Multiple command will be 
issued, even though the conditions for Read Line 
have been met. 

If the Read Multiple mode is enabled and the Read 
Line mode has been disabled, Read Multiple com¬ 
mands will still be issued if the Read Multiple con¬ 
ditions are met. 

Unsupported PCI Commands 

The SYM53C895 does not respond to reserved 
commands, special cycle, dual address cycle, or 
interrupt acknowledge commands as a slave. It will 
never generate these commands as a master. 


Configuration Registers 

The Configuration registers are accessible only by 
system BIOS during PCI configuration cycles, and 
are not available to the user at any time. No other 
cycles, including SCRIPTS operations, can access 
these registers. The lower 128 bytes hold configu¬ 
ration data while the upper 128 bytes hold the 
SYM53C895 operating registers, which are 
described in Chapter Five, “Operating Registers.” 
These registers can be accessed by SCRIPTS or 
the host processor. 

Note: the configuration register descriptions 
provide general information only, to 
indicate which PCI configuration addresses 
are supported in the SYM53C895. For 
detailed information, refer to the PCI 
Specification. 

Table 3-2 shows the PCI configuration registers 
implemented by the SYM53C895. Addresses 40h 
through 7Fh are not defined. 

All PCI-compliant devices, such as the 
SYM53C895, must support the Vendor ID, Device 
ID, Command, and Status Registers. Support of 
other PCI-compliant registers is optional. In the 
SYM53C895, registers that are not supported are 
not writable and will return all zeroes when read. 
Only those registers and bits that are currently 
supported by the SYM53C895 are described in 
this chapter. For more detailed information on 
PCI registers, please see the PCI Specification. 
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31 

16 

15 

0 


Device ID 

= OOOCh 

Vendor ID = lOOOh 

00h 

Status 

Command 

04h 

Class Code = OlOOOOh 

Rev ID = OXh 

08h 

Not Supported 

Header Type 

Latency Timer 

Cache Line 
Size 

OCh 

Base Address Zero (I/O) 1 

lOh 

Base Address One (Memory) 2 

14h 

RAM Base Address 3 

18h 

Not Supported 

ICh 

Not Supported 

20h 

Not Supported 

24h 

Reserved 

28h 

Subsystem ID 

Subsystem Vendor ID 

2Ch 

Expansion ROM Base Address 4 

3 Oh 

Reserved 

34h 

Reserved 

38h 

MaxJLat 

Min_Gnt 

Interrupt Pin 

Interrupt Line 

3Ch 

1 I/O Base is supported 

2 Memory Base is supported 

Note: Addresses 40h to 7Fh are not defined. All unsupported registers are not writable and will 
return all zeroes when read. Reserved registers will also return zeroes when read. 

3 This register powers up enabled and can be disabled by pull-down resistors on the MADS pin 

4 If expansion memory is enabled through pull-down resistors on the MAD (7-0) bus. 


Figure 3-1: PCI Configuration Register Map 
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Register OOh 
Vendor ID 
Read Only 

This field identifies the manufacturer of the device. 
The Symbios Logic Vend or ID is lOOOh. 


Register 02h 
Device ID 
Read Only 

This field identifies the particular device. The 
SYM53C895 device ID is OCh. 


Register 04h 

Command 

Read/Write 

The Command Register, illustrated in Figure 3-2, 
provides coarse control over a device’s ability to 
generate and respond to PCI cycles. When a zero is 
written to this register, the SYM53C895 is logi¬ 
cally disconnected from the PCI bus for all 
accesses except configuration accesses. 

In the SYM53C895, bits 3 through 5 and bit 7 and 
9 are not implemented. Bits 10 through 15 are 
reserved. 

Bits 15-9 Reserved 

Bit 8 SERR/ Enable 

This bit enables the SERR/ driver. SERR/ is 
disabled when this bit is clear. The default 
value of this bit is zero. This bit and bit 6 must 
be set to report address parity errors. 

Bit 7 Reserved 

Bit 6 Enable Parity Error Response 

This bit allows the SYM53C895 to detect par¬ 
ity errors on the PCI bus and report these 
errors to the system. Only data parity checking 
is enabled.The SYM53C895 always generates 
parity for the PCI bus. 

Bits 5 Reserved 


Bit 4 Write and Invalidate Mode 

This bit, when set, will cause Memory Write 
and Invalidate cycles to be issued on the PCI 
bus after certain conditions have been met. For 
more information on these conditions, refer to 
the section "Memory Write and Invalidate 
Command". To enable Write and Invalidate 
Mode, bit 0 in the CTEST3 register (operating 
register set) must also be set. 

Bit 3 Reserved 

Bit 2 Enable Bus Mastering 

This bit controls the SYM53C895’s ability to 
act as a master on the PCI bus. A value of zero 
disables the device from generating PCI bus 
master accesses. A value of one allows the 
SYM53C895 to behave as a bus master.The 
SYM53C895 must be a bus master in order to 
fetch SCRIPTS instructions and transfer data. 

Bit 1 Enable Memory Space 

This bit controls the SYM53C895’s response 
to Memory Space accesses. A value of zero dis¬ 
ables the device response. A value of one allows 
the SYM53C895 to respond to Memory Space 
accesses at the address specified by Base 
Address One. 

Bit 0 Enable I/O Space 

This bit controls the SYM53C895’s response 
to I/O space accesses. A value of zero disables 
the response. A value of one allows the 
SYM53C895 to respond to I/O space accesses 
at the address specified in Base Address Zero. 
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Reserved 
Reserved 
Reserved . 
Reserved _ 
Reserved _ 


E 

111 

13 

12 

E 

m 

I 

H 

LL 

K 

I 

E 

K 

0 

LL 

0 


Reserved 
Not Implemented 
SERR/ Enable - 


Not Implemented 
Enable Parity Response _ 

Not Implemented_ 

Write and Invalidate Mode_ 

Not Implemented_ 


Enable Bus Mastering 
Enable Memory Space . 


Enable I/O Space 


Figure 3-2: Command Register Layout 


Register 06h 

Status 

Read/Write 

The Status Register, illustrated in Figure 3-3, is 
used to record status information for PCI bus- 
related events. 

In the SYM53C895, bits 0 through 4 are reserved 
and bits 5, 6, 7, and 11 are not implemented by 
the SYM53C895. 

Reads to this register behave normally. Writes are 
slightly different in that bits can be cleared, but not 
set. A bit is reset whenever the register is written, 
and the data in the corresponding bit location is a 
one. For instance, to clear bit 15 and not affect any 
other bits, write the value 8000h to the register. 

Bit 15 Detected Parity Error (from Slave) 

This bit will be set by the SYM53C895 when¬ 
ever it detects a data parity error, even if parity 
error handling is disabled. 


Bit 14 Signaled System Error 

This bit is set whenever a device asserts the 
SERR/ signal. 

Bit 13 Master Abort (from Master) 

This bit should be set by a master device when¬ 
ever its transaction (except for Special Cycle) is 
terminated with master-abort. All master 
devices should implement this bit. 

Bit 12 Received Target Abort (from 
Master) 

This bit should be set by a master device when¬ 
ever its transaction is terminated with a target 
abort. All master devices should implement 
this bit. 

Bit 11 Reserved 

Bits 10-9 DEVSEL/Timing 

These bits encode the timing of DEVSEIV. 
These are encoded as 00b for fast, 01b for 
medium, 10b for slow with lib reserved. 

These bits are read-only and should indicate 
the slowest time that a device asserts DEVSEIV 
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for any bus command except Configuration 
Read and Configuration Write. In the 
SYM53C895, 01b is supported. 

Bit 8 Data Parity Reported 

This bit is set when the following three condi¬ 
tions are met: 1) The bus agent asserted 
PERR/ itself or observed PERR/ asserted; 2) 
The agent setting this bit acted as the bus mas¬ 


ter for the operation in which the error 
occurred; 3) The Parity Error Response bit in 
the Command register is set. 

Bits 7-0 Reserved 



14 

CO 

|12 

ii 

10 

I 


H 

I 

GE 

E 

I 

E 

E 

m 


Signaled System Error 
Received Master Abort (from Master) 
Received Target Abort (from Master) . 
Reserved (Not Supported) _ 


DEVSEL timing _r 

00 = fast, 01 = medium, 10 = slow 

Data Parity Reported 
Reserved (Not Supported) 
Reserved _ 

Reserved_ 

Reserved_ 

Reserved_ 

Reserved - 

Reserved - 

Reserved_ 


Figure 3-3: Status Register Layout 


Register 08h 
Revision ID 
Read Only 

This register specifies device and revision identifi¬ 
ers. In the SYM53C895, the upper nibble will be 
0000b. The lower nibble reflects the current revi¬ 
sion level of the device. It should have the same 
value as the Chip Revision Level bits in the 
CTEST3 register. 


Register 09h 
Class Code 
Read Only 

This register is used to identify the generic func¬ 
tion of the device. The upper byte of this register is 
a base class code, the middle byte is a subclass 
code, and the lower byte identifies a specific regis¬ 
ter-level programming interface. The value of this 
register is OlOOOOh, which indicates a SCSI con¬ 
troller. 
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Register OCh 
Cache Line Size 
Read/Write 

This register specifies the system cache line size in 
units of 32-bit words. Cache mode is enabled and 
disabled by the Cache Line Size Enable (CLSE) 
bit, bit 7 in the DCNTL register. Setting this bit 
causes the SYM53C895 to align to cache line 
boundaries before allowing any bursting, except 
during Memory Moves in which the read and write 
addresses are not aligned to a burst size boundary. 
For more information on this register, see the sec¬ 
tion "Support for PCI Cache Line Size Register". 


Register ODh 
Latency Timer 
Read/W rite 

The Latency Timer register specifies, in units of 
PCI bus clocks, the value of the Latency Timer for 
this PCI bus master.The SYM53C895 supports 
this timer. All eight bits are writable, allowing 
latency values of 0-255 PCI clocks. Use the follow¬ 
ing equation to calculate an optimum latency value 
for the SYM53C895: 

Latency = 2 + (Burst Size * (typical wait states +1)). 
Values greater than optimum are also acceptable. 


Register OEh 
Header Type 
Read Only 

This register identifies the layout of bytes 1 Oh 
through 3Fh in configuration space and also 
whether or not the device contains multiple func¬ 
tions. The value of this register is OOh. 


Register lOh 

Base Address Zero (I/O) 

Read/Write 

This 32-bit register has bit zero hardwired to one. 
Bit 1 is reserved and must return a zero on all 
reads, and the other bits are used to map the 
device into I/O space. 


Register 14h 

Base Address One (Memory) 

Read/Write 

This register has bit 0 hardwired to zero. For 
detailed information on the operation of this regis¬ 
ter, refer to the PCI Specification. 


Register 18h 
RAM Base Address 
Read/Write 

This register holds the memory base address of the 
4 KB internal RAM. The user can read this regis¬ 
ter through the SCRATCHB register in the oper¬ 
ating register set when bit 3 of the CTEST2 
register is set. 


Register 2C-2D 
Subsystem Vendor ID 
Read Only 

This register is used to uniquely identify the ven¬ 
dor manufacturing the add-in board or subsystem 
where the SYM53C895 resides. It provides a 
mechanism for an add-in card vendor to distin¬ 
guish its cards from another vendor’s cards, even if 
the cards use the same PCI controller (and there¬ 
fore have the same Vendor ID and Device ID). See 
the Serial EEPROM Interface section in Chapter 2 
for information about the values to load in this reg¬ 
ister. If the external serial EEPROM interface is 
enabled, this register is automatically loaded at 
power-up from the EEPROM. All of the bits in this 
register are cleared if serial EEPROM access is not 
enabled. 
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Register 2E-2F 
Subsystem ID 
Read Only 

This register is used to uniquely identify the board 
or subsystem where the SYM53C895 resides. It 
provides a mechanism for an add-in card vendor to 
distinguish between its cards that use the same 
PCI controller (and therefore have the same ven¬ 
dor ID, Device ID, and Subsystem Vendor ID), 
See the Serial EEPROM Interface section in 
Chapter 2 for information about the values to load 
in this register. If the external serial EEPROM 
interface is enabled, this register is automatically 
loaded at powerup from the EEPROM, All of the 
bits in this register are cleared if serial EEPROM 
access is not enabled. 

Bit 15 of this register indicates whether the 
SYM53C895 is being controlled by Symbios Logic 
software or by a different device driver. A value of 
0 indicates that the Symbios Logic software con¬ 
trols the chip, and a value of 1 indicates another 
driver. 


Register 30h 

Expansion ROM Base Address 
Read/Write 

This four-byte register handles the base address 
and size information for expansion ROM. It func¬ 
tions exactly like the Base Address Zero and Base 
Address One registers, except that the encoding of 
the bits is different. The upper 21 bits correspond 
to the upper 21 bits of the expansion ROM base 
address. 

The Expansion ROM Enable bit, bit 0, is the only 
bit defined in this register. This bit is used to con¬ 
trol whether or not the device accepts accesses to 
its expansion ROM. When the bit is set, address 
decoding is enabled, and a device can be used with 
or without an expansion ROM depending on the 
system configuration. To access the external mem¬ 
ory interface, the Memory Space bit in the Com¬ 
mand register must also be set. 


The host system detects the size of the external 
memory by first writing the Expansion ROM Base 
Address register with all ones and then reading 
back the register. The SYM53C895 will respond 
with zeros in all don’t care locations. The ones in 
the remaining bits represent the binary version of 
the external memory size. For example, to indicate 
an external memory size of 32 KB, this register, 
when written with ones and read back, will return 
ones in the upper 17 bits. 


Register 3Ch 
Interrupt Line 
Read/Write 

This register is used to communicate interrupt line 
routing information. POST software will write the 
routing information into this register as it initiates 
and configures the system. The value in this regis¬ 
ter tells which input of the system interrupt con- 
troller(s) the device’s interrupt pin has been 
connected to. Values in this register are specified by 
system architecture. 


Register 3Dh 
Interrupt Pin 
Read Only 

This register tells which interrupt pin the device 
uses. Its value is set to Olh, for the INTA/ signal. 
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Register 3Eh 
Min_Gnt 
Read Only 


Register 3Fh 
MaxJLat 
Read Only 

These registers are used to specify the desired set¬ 
tings for LatencyTimer values. Min_Gnt is used to 
specify how long a burst period the device needs. 
Max_Lat is used to specify how often the device 
needs to gain access to the PCI bus. The value 
specified in these registers is in units of 0.25 
microseconds. Values of zero indicate that the 
device has no major requirements for the settings 
of Latency Timers. The SYM53C895 sets the 
Min_Gnt register to 1 lh and the Max_Lat register 
to 40h. 
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Chapter 4 

Signal Descriptions 


This chapter presents the SYM53C895 pin config¬ 
uration and signal definitions using tables and 
illustrations. Figure 4-1 is the pin diagram for the 
SYM53C895 and Figure 4-2 is the functional sig¬ 
nal grouping. The pin definitions are in Table 4-2 
through Table 4-12. The pin definitions are orga¬ 
nized into the following functional groups: System, 
Address/Data, Interface Control, Arbitration, 

Error Reporting, SCSI, and Optional Interface. A 
slash (/) at the end of the signal name indicates that 
the active state occurs when the signal is at a low 
voltage. When the slash is absent, the signal is 
active at a high voltage. 


Voltage Capabilities and 
Limitations 

The SYM53C895 uses 5V biasing pins to allow 
the device to handle up to 5 Volt input voltage to 
the PCI and external memory interface pins. When 
the SYM53C895 is used in a 5 Volt PCI system, 
the biasing pins (V5BIAS (P)) must be supplied 
with 5 Volts; when they are used in a 3 Volt only 
PCI environment, they must be supplied with 3.3 
Volts. The external memory pins (GPIO pins and 
MAD7-0) also use 5 Volt-tolerant I/O pads. They 
also have a 5 Volt biasing pin (V5BIAS(M)).These 
pins should be supplied with 5 Volts when using 5 
Volt memory devices, and with 3.3 Volts when 
using 3.3 Volt memory devices. The SCLK input is 
also a 5V-tolerant input pin. 

The chip cannot operate normally if the 5 Volt 
biasing pins are grounded or disconnected. In 
addition, the PCI biasing pins should not be 
shorted to the memory bias pin if mixed voltage 
environments (such as 5 Volt PCI with 3 Volt mem¬ 
ories) are possible. All other Vpj, supplies to the 
SYM53C895 must be set for 3.3 Volt operation. In 
addition, the chip will only drive 3.3 Volts on any 
of the pins when they operate as outputs. 
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The decoupling capacitor arrangement s/iown above is recommended to maximize the benefits of the internal split ground system. 
Capacitor values between 0.01 and 0. ljiF should provide adequate noise isolation. Because of the number of high current drivers on 
the SYM53CS95, a multi-layer PC board with power and ground planes is required. _ __ 


Figure 4-1 s SYM53C895 Pin Diagram 


There are four signal type definitions: 

I Input, a standard input-only signal 

O Totem Pole Output, a standard output driver 

T/S Tri-State, a bi-directional, tri-state input/output pin 

S/T/S Sustained tri-state, an active low tri-state signal owned and driven by one and only one 

agent at a time 
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Internal Pull-ups on SYM53C895 Pins 

Several pins on the SYM53C895 use internal pull-ups. Table 4-1 describes the conditions under which 
these pull-ups are enabled or disabled. 

Table 4-1: SYM53C895 Internal Pull-ups 

Pin Name Pull-up current Conditions for pull-up 


Pull-ups enabled when and-tree mode is enabled by 
driving TESTIN low 


PCI pins except IRQ, CLK and RST 

25 pA 

IRQ 

25 pA 

RST, CLK 

n/a 

MAD (7-0) 

n/a 

MAS/(l-0), MCE/, MOE/,MWE/ 

25 pA 

GPIO(4-0) 

n/a 

SCSI pads and SCLK 

n/a 

RBIAS+, RBIAS- 

n/a 

DIFFSENS 

n/a 

BIG_LIT/ 

25 pA 

MAC/_TESTOUT 

n/a 

TEST pin 82 

25 pA 

TEST pin 177 

25 pA 

TESTIN 

25 pA 

TESTO 

25 pA 

TEST pins 180, 181, 182, 183 

25 pA 


Pull-up enabled when and-tree mode is enabled by 
driving TESTIN low or when the IRQ mode bit (bit 3 
of DCNTL (3Rh)) is cleared* 

No pull-up 
No pull-ups 

Pull-up enabled when and-tree mode is enabled by 
driving TESTIN low or if the ZMODE bit (bit7 of 
CTEST4 (21h)) is set 

No pull-ups 
No pull-ups 
No pull-ups 

No pull-up, analog input protect pin 

Pull-up enabled when and-tree mode is enabled by 
driving TESTIN low 

No pull-up, output only 
Pull-up all the time 
Pull-up all the time 
Pull-up all the time 
Pull-up all the time 

Pull-up enabled when and-tree mode is enabled by 
driving TESTTN low or if a hidden bit (bit7 of 
STESTO (4Ch)) is cleared (default = cleared) 


*When bit 3 of DCNTL is set> the pad becomes a totem pole output pad and wiU drive both high and low 
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Table 4-2: 53C895 Power and Ground Pins 


Symbol 

Pin No. 

Description 

V SS-POI 

8, 18,31,41,56, 

193,200 

Power supplies to the PCI I/O pins 

V DD-PCI 

2, 13, 23,26,36, 46, 
60,197 

Power supplies to the PCI I/O pins 

V SS-SCSI 

91, 110, 120,128, 

131,139,151,169 

Power supplies to the SCSI bus I/O pins 

VpD-SCSI 

86,96, 115, 125, 

134, 144,164, 174 

Power supplies to the SCSI bus I/O pins 

V SS-IO 

78, 179 

Power supplies to the external memory interface 

V DD-IO 

73,81, 184 

Power supplies to the external memory interface 

V SS-OORE 

68, 187 

Power supplies to the internal logic core 

V DD-CORE 

64,190 

Power supplies to the internal logic core 

Vss-A 

83 

Power pins used by analog circuitry 

V DD-A 

85 

Power pins used by analog circuitry 

V5BIAS(P) 

4, 49 

5 Volt biasing pins for PCI signals. These pins must be supplied 
with 5V in a 5V PCI environment, or 3.3 V when used in a 3V 
only PCI environment. 

V5BIAS(M) 

62 

5 Volt biasing pin for external memory interface signals. When 
using 5V memory devices, this pin should be supplied with 5V. 
When using 3.3V memory devices, it should be supplied with 
3.3V. 

All V dd P* n$ must be supplied 3.3 Volts. The SYM53C895 output signals drive 3.3 V. 


Note: if you apply separate power supplies to the Vdd-IO and Vq^.qqre pins in a chip testing 

environment, either power up the pins simultaneously or power up Vdd-CORE before Vdd-IO. The 
Vdd-IO Pin s must always power down before Vdd-CORE- 
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Table 4-3: System Pins 


Symbol 

Pin No. Type 

Description 

CLK 

195 I 

Clock provides timing for all transactions on the PCI bus and is 
an input to every PCI device. All other PCI signals are sampled 
on the rising edge of CLK, and other timing parameters are 
defined with respect to this edge. This clock can optionally be 
used as the SCSI core clock; however, the SYM53C895 will not 
be able to achieve Fast SCSI-2 (or faster) transfer rates. 

RST/ 

194 I 

Reset forces the PCI sequencer of each device to a known state. 

All T/S and S/T/S signals are forced to a high impedance state, 
and all internal logic is reset. The RST/ input is synchronized 
internally to the rising edge of CLK. The CLK input must be 
active while RST/ is active to properly reset the device. 

Table 4-4: Address and Data Pins 

Symbol 

Pin No. Type 

Description 

AD (31-0) 

199,201- T/S 

204,3, 5, 6, 

10-12, 14- 
17, 19,33- 
35,37-40, 

42,44,45, 

47,48, 50, 

51,57, 58 

Physical longword address and data are multiplexed on the 
same PCI pins. During the first clock of a transaction, 
AD(31-0) contain a physical address. During subsequent 
clocks, AD(31-0) contain data. A bus transaction consists of 
an address phase, followed by one or more data phases. PCI 
supports both read and write bursts. AD(7-0) define the least 
significant byte, and AD (31-24) define the most significant 
byte. 

C_BE(3-0)/ 

7, 20,32,43 T/S 

Bus commands and byte enables are multiplexed on the same 
PCI pins. During the address phase of a transaction, 

C _BE(3-0)/ define the bus command. During the data phase, 
C_BE(3-0)/ are used as byte enables. The byte enables deter¬ 
mine which byte lanes carry meaningful data. C_BE(0)/ 
applies to byte 0, and C_BE(3)/ to byte 3. 

PAR 

30 T/S 

Parity is the even parity bit that protects the AD(31-0) and 
C_BE(3-0)/ lines. During address phase, both the address 
and command bits are covered. During data phase, both data 
and byte enables are covered. 
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Table 4-5: Interface Control Pins 


Symbol 

Pin No. 

Type 

Description 

FRAME/ 

21 

S/T/S 

Cycle Frame is driven by the current master to indicate the begin¬ 
ning and duration of an access. FRAME/ is asserted to indicate a 
bus transaction is beginning. While FRAME/ is asserted, data trans¬ 
fers continue. When FRAME/ is deasserted, the transaction is in 
the final data phase or the bus is idle. 

TRDY/ 

24 

S/T/S 

Target Ready indicates the selected device’s ability to complete the 
current data phase of the transaction. TRDY/ is used with IRDY/. A 
data phase is completed on any clock when both TRDY/ and IRDY/ 
are sampled asserted. During a read, TRDY/ indicates that valid 
data is present on AD(31-0). During a write, it indicates the target 
is prepared to accept data. Wait cycles are inserted until both IRDY/ 
and TRDY/ are asserted together. 

IRDY/ 

22 

S/T/S 

Initiator Ready indicates the bus master’s ability to complete the 
current data phase of the transaction. This signal is used with 

TRDY/. A data phase is completed on any clock when both IRDY/ 
and TRDY/ are sampled asserted. During a write, IRDY/ indicates 
that valid data is present on AD (31-0). During a read, it indicates 
the master is prepared to accept data. Wait cycles are inserted until 
both IRDY/ and TRDY/ are asserted together. 

STOP/ 

27 

S/T/S 

Stop indicates that the selected target is requesting the master to 
stop the current transaction. 

DEVSEL/ 

25 

S/T/S 

Device Select indicates that the driving device has decoded its 
address as the target of the current access. As an input, it indicates 
to a master whether any device on the bus has been selected. 

IDSEL 

9 

I 

Initialization Device Select is used as a chip select in place of the 
upper 24 address lines during configuration read and write transac¬ 
tions. 

Table 4-6: Arbitration Pins 

Symbol 

Pin No. 

Type 

Description 

REQ/ 

198 

O 

Request indicates to the arbiter that this agent desires use of the 

PCI bus. This is a point-to-point signal. Every master has its own 
REQ/. 

GNT/ 

196 

I 

Grant indicates to the agent that access to the PCI bus has been 
granted. This is a point-to-point signal. Every master has its own 
GNT/. 
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Table 4-7: Error Reporting Pins 


Symbol 

Pin No. 

Type 

Description 

PERR/ 

28 

S/T/S 

Parity Error may be pulsed active by an agent that detects a data 
parity error. PERR/ can be used by any agent to signal data corrup¬ 
tions. 

SERR/ 

29 

O 

This open drain output pin is used to report address parity errors. 

On detection of a PERR/ pulse, the central resource may generate a 
non-maskable interrupt to the host CPU, which often implies the 
system will be unable to continue operation once error processing is 
complete. 

Table 4-8: SCSI Pins, LVDlink Mode 

Symbol 

Pin No. 


Type Description 


SCLK 80 I SCLK is used to derive all SCSI-related timings. The speed of this 

clock is determined by the application’s requirements; in some 
applications SCLK may be sourced internally from the PCI bus 
clock (CLK). If SCLK is internally sourced, then the SCLK pin 
should be tied low. For Ultra2 SCSI operation, this pin must be 
connected to an external 40 MHz oscillator, used with the internal 
clock quadrupler. 

SD-(15-0), 167, 170, 172, I/O Negative half of LVDlink signal pair for SCSI data lines. SCSI 

SDP-(l-O) 175, 87, 89, 92, Data includes the following data lines and parity signals: SD(15- 

94, 135, 137, 0)/ (16-bit SCSI data bus), and SDP(l-0)/(SCSI data parity bits). 

140, 142, 145, 

147, 149, 162, 

165,132 


SD+(15-0), 168, 171, 173, I/O Positive half of LVDlink signal pair for SCSI data lines. 

SDP+(l-0) 176,88,90,93, 

95, 136, 138, 

141, 143, 146, 

148,150, 163, 

166,133 

SCTRL- 111, 97, 116, 99, I/O Negative half of LVDlink signal pair for SCSI Control, which 

121, 123, 126, includes the following signals: 

118, 113 SCD- SCSI phase line, command/data 

SIO- SCSI phase line, input/output 

SMSG- SCSI phase line, message 

SREQ- Data handshake signal from target device 

SACK- Data handshake signal from initiator device 
SBSY- SCSI bus arbitration signal, busy 
SATN- SCSI Attention, the initiator is requesting a message 
out phase 

SRST SCSI bus reset 

SSEL- SCSI bus arbitration signal, select device 
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Table 4-8: SCSI Pins, LVDlink Mode (Continued) 


Symbol 

Pin No. 

Type 

Description 

SCTRL+ 

112, 98, 117, 
100, 122, 124, 
127,119,114 

I/O 

Positive half of LVDlink signal pair for SCSI Control, which 
includes the following signals: 

SCD+ SCSI phase line, command/data 

SIO+ SCSI phase line, input/output 

SMSG+ SCSI phase line, message 

SREQ+ Data handshake signal from target device 

SACK+ Data handshake signal from initiator device 

SBSY+ SCSI bus arbitration signal, busy 

SATN+ SCSI Attention, the initiator is requesting a message 
out phase 

SRST+ SCSI bus reset 

SSEL+ SCSI bus arbitration signal, select device 

RBIAS+, 

RBIAS- 

130, 129 

I 

Used to connect an external resistor to generate the bias current 
used by LVDlink pads. 

DIFFSENS 

84 

I 

The Differential Sense pin detects the voltage level of an incoming 
SCSI signal to determine whether it is from a single-ended, LVD, 
or high-power differential device. The result is displayed in 

STEST4 bits 7-6, 




When external differential transceivers are used and a high level is 
detected on this pin, all chip SCSI outputs will be tri-stated to 
avoid damage to the transceivers. This pin should be connected to 
the DIFFSENS signal on the SCSI cable. 




Note: the maximum voltage allowed to this pin is 3.3 Volts. 



Table 4-9: 

SCSI Pins, Single-Ended Mode 

Symbol 

Pin No. 

Type 

Description 

SCLK 

80 

I 

SCLK is used to derive all SCSI-related timings. The speed of this 
clock is determined by the application’s requirements; in some 
applications SCLK may be sourced internally from the PCI bus 
clock (CLK). If SCLK is internally sourced, then the SCLK pin 
should be tied low. 

SD-(15-0), 

SDP-(l-O) 

167, 170, 172, 
175, 87, 89, 92, 
94, 135, 137, 
140, 142, 145, 
147, 149, 162, 
165,132 

I/O 

SCSI Data includes the following data lines and parity signals: 
SD(15-0)/ (16-bit SCSI data bus), and SDP(l-0)/(SCSI data par¬ 
ity bits). 

SD+(15-0), 

SDP-Kl-O) 

168, 171, 173, 
176, 88, 90, 93, 
95, 136, 138, 
141, 143, 146, 
148, 150, 163, 
166,133 

o 

These signals will drive 0 Volts. 
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Table 4-9: SCSI Pins, Single-Ended Mode (Continued) 


Symbol 

Pin No. 

Type 

Description 

SCTRL- 

111,97, 116,99, 
121, 123, 126, 

118,113 

I/O 

SCSI Control, includes the following signals: 

SCD- SCSI phase line, command/data 

SIO- SCSI phase line, input/output 

SMSG- SCSI phase line, message 

SREQ- Data handshake signal from target device 

SACK- Data handshake signal from initiator device 

SBSY- SCSI bus arbitration signal, busy 

SATN- SCSI Attention, the initiator is requesting a message 
out phase 

SRST- SCSI bus reset 

SSEL- SCSI bus arbitration signal, select device 

SCTRL+ 

112, 98, 117, 

100, 122, 124, 

127,119,114 

o 

These pins drive 0 Volts. 

DIFFSENS 

84 

I 

The Differential Sense pin detects the voltage level of an incoming 
SCSI signal to determine whether it is from a single-ended, LVD, 
or high-power differential device. The result is displayed in 

STEST4 bits 7-6. 




When external differential transceivers are used and a high level is 
detected on this pin, all chip SCSI outputs will be tri-stated to 
avoid damage to the transceivers. This pin should be connected to 
the DIFFSENS signal on the SCSI cable. 

Note: the maximum voltage allowed to this pin is 3.3 Volts. 

Table 4-10: SCSI Pins, High Voltage Differential Mode 

Symbol 

Pin No. 

Type 

Description 

SCLK 

80 

I 

SCLK is used to derive all SCSI-related timings. The speed of this 
clock is determined by the application’s requirements; in some 
applications SCLK may be sourced internally from the PCI bus 
clock (CLK). If SCLK is internally sourced, then the SCLK pin 
should be tied low. 

SD-(15-0), 

SDP-(l-O) 

167, 170, 172, 

175, 87, 89, 92, 
94, 135, 137, 

140, 142, 145, 

147, 149, 162, 

165,132 

I/O 

SCSI data lines. SCSI Data includes the following data lines and 
parity signals: SD(15-0)/ (16-bit SCSI data bus), and SDP(l-O)/ 
(SCSI data parity bits). 

SD+(15-0), 

SDP+(l-0) 

168, 171, 173, 

176, 88, 90, 93, 
95, 136, 138, 

141, 143, 146, 

148, 150, 163, 

166, 133 

o 

Driver direction control for SCSI data lines. 
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Table 4-10: SCSI Pins, High Voltage Differential Mode (Continued) 

Symbol Pin No. Type Description 

SCTRL- 111, 97, 116, 99, I/O SCSI Control includes the following signals: 

121, 123, 126, SCD- SCSI phase line, command/data 

118, 113 SIO- SCSI phase line, input/output 

SMSG- SCSI phase line, message 

SREQ- Data handshake signal from target device 

SACK- Data handshake signal from initiator device 
SBSY- SCSI bus arbitration signal, busy 
SATN- SCSI Attention, the initiator is requesting a message 
out phase 

SRST- SCSI bus reset 

SSEL- SCSI bus arbitration signal, select device 

SCTRL+ 112, 98, 117, O Driver direction control for the external transceivers, which 

100, 122, 124, includes the following signals: 

127, 119, 114 SREQ+ Data handshake signal from target device 

SACK+ Data handshake signal from initiator device 
SBSY+ SCSI bus arbitration signal, busy 

SRST+ SCSI bus reset 

SSEL+ SCSI bus arbitration signal, select device 

Note: for high voltage differential operation SCD+, SIO+, 
SMSG+, and SATN+ are not used. 

DIFFSENS 84 I The Differential Sense pin detects the voltage level of an incoming 

SCSI signal to determine whether it is from a single-ended, LVD, 
or high-power differential device. The result is displayed in 
STEST4 bits 7-6. 

When external differential transceivers are used and a high level is 
detected on this pin, all chip SCSI outputs will be tri-stated to 
avoid damage to the transceivers. This pin should be connected to 
the DIFFSENS signal on the SCSI cable. 

Note: the maximum voltage allowed to this pin is 3.3 Volts. 


Table 4-11: Additional Interface Pins 

Type Description 

I Test In. When this pin is driven low, the SYM53C895 connects all 

inputs and outputs to an “AND tree.”The SCSI control signals 
and data lines are not connected to the “AND tree.” The output of 
the “AND tree” is connected to the Test Out pin. This allows man¬ 
ufacturers to verify chip connectivity and determine exacdy which 
pins are not properly attached. When the TESTIN pin is driven 
low, internal pull-ups are enabled on all input, output, and bidirec¬ 
tional pins, all outputs and bidirectional signals will be tri-stated, 
and the MAC/_TESTOUT pin will be enabled. Connectivity can 
be tested by driving one of the SYM53C895 pins low. The MAC/ 
_TESTOUT pin should respond by also driving low. 


Symbol Pin No. 

TESTIN 178 
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Symbol Pin No. 

GPIOO" 61 

FETCH/ 


GPI01_ 63 

MASTER/ 


GPI04-2 67-65 


MAC/_ 79 

TESTOUT 


IRQ/ 59 


Table 4-11: Additional Interface Pins (Continued) 

Type Description 

I/O General Purpose I/O pin. Optionally, when driven low, indicates 

that the next bus request will be for an op code fetch. This pin pow¬ 
ers up as a general purpose input. 

This pin has two specific purposes in the Symbios Logic software. 
The software uses it to toggle SCSI device LEDs, turning on the 
LED whenever the SYM53C895 is on the SCSI bus. The software 
drives this pin low to turn on the LED, or drives it high to turn off 
the LED. This signal can also be used as data I/O for serial 
EEPROM access. In this case it is used with the GPIOl pin, which 
serves as a clock. 

I/O General purpose I/O pin. Optionally, when driven low, indicates 
that the SYM53C895 is bus master.This pin powers up as a gen¬ 
eral purpose input. 

Symbios Logic software supports use of this signal in serial 
EEPROM applications, when enabled, in combination with the 
GPIOO pin. When this signal is used as a clock for serial EEPROM 
access, the GPIOO pin serves as data. 

I/O General purpose I/O pins. GPI04 powers up as an output. Sym¬ 
bios Logic software also supports use of this signal as the enable 
line for Vpp, the 12 Volt power supply to the external flash memory 
interface. GPI03-2 power up as inputs. 

T/S Memory Access Control. This pin can be programmed to indicate 

local or system memory accesses (non-PCI applications). It is also 
used to test the connectivity of the SYM53C895 signals using an 
“AND tree” scheme. The MAC/_TESTOUT pin is only driven as 
the Test Out function when the TESTIN/ pin is driven low. 

O Interrupt. This signal, when asserted low, indicates that an inter¬ 
rupting condition has occurred and that service is required from 
the host CPU.The output drive of this pin is programmed as either 
open drain with an internal weak pull-up or, optionally, as a totem 
pole driver. Refer to the description of DCNTL Register, bit 3, for 
additional information. 
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Table 4-11: Additional Interface Pins (Continued) 


Symbol Pin No. Type Description 

BIG_LIT/ 192 I BigJLittle Endian Select. When this pin is driven low, the 

SYM53C895 will route the first byte of an aligned SCSI to PCI 
transfer to byte lane zero of the PCI bus and subsequent bytes 
received will be routed to ascending lanes. An aligned PCI to SCSI 
transfer will route PCI byte lane zero onto the SCSI bus firsts and 
transfer ascending byte lanes in order. When this pin is driven high, 
the SYM53C895 will route the first byte of an aligned SCSI-to- 
PCI transfer to byte lane three of the PCI bus and subsequent 
bytes received will be routed to descending lanes. An aligned PCI- 
to-SCSI transfer will route PCI byte lane three onto the SCSI bus 
first and transfer descending byte lanes in order. This mode of 
operation also applies to the external memory interface. When this 
pin is driven in Litde Endian mode and the chip is performing a 
read from external memory, the byte of data accessed at location 
OOOOOh will be routed to PCI byte lane zero and the data accessed 
at location 00003h will be routed to PCI byte lane three. When the 
chip is performing a write to flash memory, PCI byte lane zero will 
be routed to location OOOOOh and ascending byte lanes will be 
routed to subsequent memory locations. When this pin is driven in 
Big Endian mode and the chip is performing a read from external 
memory, the byte of data accessed at location OOOOOh will be 
routed to PCI byte lane three and the data accessed at location 
00003h will be routed to byte lane zero. When the chip is perform¬ 
ing a write to flash memory, PCI byte lane three will be routed to 
location OOOOOh and descending byte lanes will be routed to subse¬ 
quent memory locations. 


Test Pins 

82, 177, 180, 
182, 183 

181, I/O 

Used by Symbios Logic for diagnostic testing. These pins should 
not be used in actual system design; they must be left floating or 
pulled high. 



Table 4-12: 

External Memory Interface Pins 

Symbol 

Pin No. 

Type 

Description 

MASO/ 

186 

O 

Memory Address Strobe O.This pin is used to latch in the least sig¬ 
nificant address byte of an external EPROM or flash memory. 

Since the SYM53C895 moves addresses eight bits at a time, this 
pin connects to the clock of an external bank of flip-flops which are 
used to assemble up to a 20-bit address for the external memory. 

MAS1/ 

185 

O 

Memory Address Strobe 1. This pin is used to latch in the address 
byte corresponding to address bits 15-8 of an external EPROM or 
flash memory. Since the SYM53C895 moves addresses eight bits at 
a time, this pin connects to the clock of an external bank of flip- 
flops which assemble up to a 20-bit address for the external mem¬ 
ory. 
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Table 4-12: External Memory Interface Pins (Continued) 

Symbol Pin No. Type Description 

MAD7-0 See individual pin The MAD7—0 pins form the memory address/data bus.This bus is 

descriptions used in conjunction with the memory address strobe pins and 

external address latches to assemble up to a 20-bit address for an 
external EPROM or flash memory. This bus will put out the most 
significant byte first and finish with the least significant byte. It is 
also used to write data to a flash memory or read data into the chip 
from external EPROM or flash memory. The eight signals on the 
MAD bus have specific functions. Please refer to the individual pin 
descriptions below. 

MAD7-6 69-70 I/O MAD(7-6) enable different power-up options related to die exter¬ 

nal serial EEPROM interface. These options are programmed by 
connecting a 4.7 K12 resistor between the appropriate MAD pin 
and Vss- For more information, refer to the Serial EEPROM Inter¬ 
face section in Chapter 2 and the Subsystem ID /Subsystem Ven¬ 
dor ID register descriptions in Chapter 3. 


MAD(7-6) 

Result 

00 

Vendor specific information is automatically down¬ 
loaded from the serial EEPROM through GPIO0 
(clock) and GOPOl (data) and loaded into PCI con¬ 
figuration registers 2C-2Fh. 

01 

Reserved 

10 

No download is performed, however the PCI config¬ 
uration registers 2C-2Fh are now writable 

11 

Vendor-specific information is automatically down¬ 
loaded from the EEPROM through GPIO0 (data) 
and GPIOl (clock) and loaded into PCI configura¬ 
tion registers 2C-2Fh. 


MAD 5 

71 

I/O The MAD5 pin enables/disables the 4K internal RAM on the 

SYM53C895. Pull this pin high to enable the SCRIPTS RAM 
(default), and pull it low (with a 4 K12 resistor) to disable the 
SCRIPTS RAM. 

MAD4 

72 

I/O The MAD (4) pin is reserved and should be pulled up. It may be 

used by Symbios Logic in future devices. 
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Table 4-12: External Memory Interface Pins (Continued) 

Symbol Pin No. Type Description 

MAD3-1 74-76 I/O The MAD(3-1) pins are used to set the size of the external parallel 

ROM device attached to the SYM53C895. Encoding for these pins 
is listed below (0 indicates a pull-down resistor is attached, 1 indi¬ 
cates not pull-down resistor is attached). 


MAD(3-1) 

Available Memory Space 

000 

16 KB 

001 

32 KB 

010 

64 KB 

Oil 

128 KB 

100 

256 KB 

101 

512 KB 

110 

1024 KB 

111 

2048 KB 


MAD 0 

77 

I/O 

MAD(0) is the slow ROM pin. When pulled down, it enables two 
extra clock cycles of data access time. This accommodates a 200 ns 
memory device on the MAD bus. When the pin is high, a 150 ns or 
faster memory device must be used. 

MWE/ 

188 

O 

Memory Write Enable. This pin is used as a write enable signal to 
an external flash memory. 

MOE/ 

189 

O 

Memory Output Enable. This pin is used as an output enable sig¬ 
nal to an external EPROM or flash memory during read opera¬ 
tions. 

MCE/ 

191 

O 

Memory Chip Enable. This pin is used as a chip enable signal to an 
external EPROM or flash memory device 
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Chapter 5 

Operating Registers 


This section contains descriptions of all 
SYM53C895 operating registers. Table 5-1 sum¬ 
marizes the SYM53C895 operating register set. 
Figure 5-1, the register map, lists registers by oper¬ 
ating and configuration addresses. The terms “set” 
and “assert” are used to refer to bits that are pro¬ 
grammed to a binary one. Similarly, the terms 
“deassert,” “clear” and “reset” are used to refer to 
bits that are programmed to a binary zero. Reserved 
bit functions may be changed at any time; these bits 
should never be set by the user. Unless otherwise 
indicated, all bits in registers are active high, that is, 
the feature is enabled by setting the bit. The bottom 
row of every register diagram shows the default reg¬ 
ister values, which are enabled after the chip is pow¬ 
ered on or reset. 


Note: the only register that the host CPU can 

access while the SYM53C895 is executing 
SCRIPTS is the ISTAT register; attempts 
to access other registers will interfere with 
the operation of the chip. However, all 
operating registers are accessible with 
SCRIPTS. All read data is synchronized 
and stable when presented to the PCI bus. 

Note: the SYM53C895 cannot fetch SCRIPTS 
instructions from the operating register 
space. Instructions must be fetched from 
system memory or the internal SCRIPTS 
RAM. 


Table 5-1: Operating Register Addresses and Descriptions 

Memory or PCI 


I/O Address Configuration 
Offset Address 

Read/Write 

Label 

Description 

Page No. 

00 

80 

R/W 

SCNTL0 

SCSI Control 0 

5-5 

01 

81 

R/W 

SCNTL1 

SCSI Control 1 

5-7 

02 

82 

R/W 

SCNTL2 

SCSI Control 2 

5-9 

03 

83 

R/W 

SCNTL3 

SCSI Control 3 

5-10 

04 

84 

R/W 

SCID 

SCSI Chip ID 

5-12 

05 

85 

R/W 

SXFER 

SCSI Transfer 

5-12 

06 

86 

R/W 

SDID 

SCSI Destination ID 

5-15 

07 

87 

R/W 

GPREG 

General Purpose Bits 

5-15 

08 

88 

R/W 

SFBR 

SCSI First Byte Received 

5-16 

09 

89 

R/W 

SOCL 

SCSI Output Control Latch 

5-16 

0A 

8A 

R 

SSID 

SCSI Selector ID 

5-17 

0B 

8B 

R/W 

SBCL 

SCSI Bus Control Lines 

5-17 

OC 

8C 

R 

DSTAT 

DMA Status 

5-18 

0D 

8D 

R 

SSTAT0 

SCSI Status 0 

5-19 
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Table 5-1: Operating Register Addresses and Descriptions (Continued) 

Memory or PCI 


I/O Address Configuration Read/Write Label 

Offset Address 

Description 

Page No. 

OE 

8E 

R 

SSTAT1 

SCSI Status 1 

5-20 

OF 

8F 

R 

SSTAT2 

SCSI Status 2 

5-21 

10-13 

90-93 

R/W 

DSA 

Data Structure Address 

5-22 

14 

94 

R/W 

ISTAT 

Interrupt Status 

5-23 

18 

98 

R/W 

CTEST0 

Reserved 

5-25 

19 

99 

R/W 

CTEST1 

Chip Test 1 

5-25 

1A 

9A 

R 

CTEST2 

Chip Test 2 

5-26 

IB 

9B 

R 

CTEST3 

Chip Test 3 

5-27 

1C-IF 

9C-9F 

R/W 

TEMP 

Temporary Register 

5-28 

20 

AO 

R/W 

DFIFO 

DMA FIFO 

5-28 

21 

A1 

R/W 

CTEST4 

Chip Test 4 

5-29 

22 

A2 

R/W 

CTEST5 

Chip Test 5 

5-30 

23 

A3 

R/W 

CTEST6 

Chip Test 6 

5-31 

24-26 

A4-A6 

R/W 

DBC 

DMA Byte Counter 

5-32 

27 

A7 

R/W 

DCMD 

DMA Command 

5-32 

28-2B 

A8-AB 

R/W 

DNAD 

DMA Next Address for Data 

5-33 

2C-2F 

AC-AF 

R/W 

DSP 

DMA SCRIPTS Pointer 

5-33 

30-33 

B0-B3 

R/W 

DSPS 

DMA SCRIPTS Pointer Save 

5-34 

34-37 

B4-B7 

R/W 

SCRATCHA 

General Purpose Scratch Pad A 

5-34 

38 

B8 

R/W 

DMODE 

DMA Mode 

5-35 

39 

B9 

R/W 

DIEN 

DMA Interrupt Enable 

5-36 

3A 

BA 

R/W 

SBR 

Scratch Byte Register 

5-37 

3B 

BB 

R/W 

DCNTL 

DMA Control 

5-37 

3C-3F 

BC-BF 

R 

ADDER 

Sum output of internal adder 

5-38 

40 

CO 

R/W 

SIEN0 

SCSI Interrupt Enable 0 

5-39 

41 

Cl 

R/W 

SIEN1 

SCSI Interrupt Enable 1 

5-40 

42 

C2 

R 

SIST0 

SCSI Interrupt Status 0 

5-41 

43 

C3 

R 

SIST1 

SCSI Interrupt Status 1 

5-42 

44 

C4 

R/W 

SLPAR 

SCSI Longitudinal Parity 

5-43 

45 

C5 

R 

SWIDE 

SCSI Wide Residue Data 

5-44 

46 

C6 

R/W 

MACNTL 

Memory Access Control 

5-45 

47 

C7 

R/W 

GPCNTL 

General Purpose Control 

5-45 

48 

C8 

R/W 

STIME0 

SCSI Timer 0 

5-46 

49 

C9 

R/W 

STIME1 

SCSI Timer 1 

5-47 
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Table 5-1: Operating Register Addresses and Descriptions (Continued) 


Memory or PCI 

I/O Address Configuration Read/Write Label 

Offset Address 

Description 

Page No. 

4A 

CA 

R/W 

RESPIDO 

Response ID 0 

5-48 

4B 

CB 

R/W 

RESPID1 

Response ID 1 

5-48 

4C 

CC 

R 

STESTO 

SCSI Test 0 

5-49 

4D 

CD 

R 

STEST1 

SCSI Test 1 

5-50 

4E 

CE 

R/W 

STEST2 

SCSI Test 2 

5-51 

4F 

CF 

R/W 

STEST3 

SCSITest 3 

5-52 

50-51 

D0-D1 

R 

SIDL 

SCSI Input Data Latch 

5-53 

52 

D2 

R 

STEST4 

SCSI Test 4 

5-54 

53 

D3 


Reserved 



54-55 

D4-D5 

RAV 

SODL 

SCSI Output Data Latch 

5-54 

56-57 

D6-D7 


Reserved 



58-59 

D8-D9 

R 

SBDL 

SCSI Bus Data Lines 

5-55 

5A-5B 

DA-DB 


Reserved 



5C-5F 

DC-DF 

R/W 

SCRATCHB 

General Purpose Scratch Pad B 

5-55 

60-7F 

EO-FF 

R/W 

SCRATCHC-J 

General Purpose Scratch Pad 

5-56 





C-J 
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Mem I/O 

Config 

SCNTL3 

SCNTL2 

SCNTL1 

SCNTLO 

00 

80 

GPREG 

SDID 

SXFER 

SCID 

04 

84 

SBCL 

SSID 

SOCL 

SFBR 

08 

88 

SSTAT2 

SSTAT1 

SSTATO 

DSTAT 

oc 

8C 

DSA 

10 

90 

RESERVED 

ISTAT 

14 

94 

CTEST3 

CTEST2 

CTEST1 

RESERVED 

18 

98 

TEMP 

1C 

9C 

CTEST6 

CTEST5 

CTEST4 

DFIFO 

20 

AO 

DCMD 

DBC 

24 

A4 

DNAD 

28 

A8 

DSP 

2C 

AC 

DSPS 

30 

BO 

SCRATCH A 

34 

B4 

DCNTL 

SBR 

DIEN 

DMODE 

38 

B8 

ADDER 

3C 

BC 

SIST1 

SISTO 

SIEN1 

SIENO 

40 ! 

CO 

GPCNTL 

MACNTL 

SWIDE 

SLPAR 

44 

C4 

RESPID1 

RESPIDO 

STIME1 

STIMEO 

48 

C8 

STEST3 

STEST2 

STEST1 

STESTO 

4C 

cc 

RESERVED 

STEST4 

SI 

DL 

50 

DO 

RESERVED 

SODL 

54 

D4 

RESERVED 

SBDL 

58 

D8 

SCRATCH B 

5C 

DC 

SCRATCHC 

60 

EO 

SCRATCHD 

64 

E4 

SCRATCHE 

68 

E8 

SCRATCHF 

6C 

EC 

SCRATCHG 

70 

FO 

SCRATCHH 

74 

F4 

SCRATCHI 

78 

F8 

SCRATCHJ 

7F 

FF 


Figure 5-1: SYM53C895 Register Address Map 
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Register 00 (80) 

SCSI Control Zero (SCNTLO) 
Read/Write 


ARBI 

ARBO 

START 

WATN 

EPC 

RES 

AAP 

TRG 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

1 1 

0 

0 

0 

X 

0 

0 


Bit 7 ARBI (Arbitration Mode bit 1) 
Bit 6 ARBO (Arbitration Mode bit 0) 


ARBI 

ARBO 

Arbitration Mode 

0 

0 

Simple arbitration 

0 

1 

Reserved 

1 

0 

Reserved 

1 

1 

Full arbitration^ selection/reselection 


Simple Arbitration 

1. The SYM53C895 waits for a bus free 
condition to occur. 

2. It asserts SBSY/ and its SCSI ID 
(contained in the SCID register) onto the 
SCSI bus. If the SSEL/ signal is asserted by 
another SCSI device, the SYM53C895 will 
deassert SBSY/, deassert its ID and set the 
Lost Arbitration bit (bit 3) in the SSTATO 
register. 

3. After an arbitration delay, the CPU should 
read the SBDL register to check if a higher 
priority SCSI ID is present. If no higher 
priority ID bit is set, and the Lost 
Arbitration bit is not set, the SYM53C895 
has won arbitration. 

4. Once the SYM53C895 has won 
arbitration, SSEL/ must be asserted via the 
SOCL for a bus clear plus a bus settle delay 
(1.2 (is) before a low level selection can be 
performed. 


Full Arbitration, Selection/Reselection 

1. The SYM53C895 waits for a bus free 
condition. 

2. It asserts SBSY/ and its SCSI ID (the 
highest priority ID stored in the SCID 
register) onto the SCSI bus. 

3. If the SSEL/ signal is asserted by another 
SCSI device or if the SYM53C895 detects 
a higher priority ID, the SYM53C895 will 
deassert BSY, deassert its ID, and wait 
until the next bus free state to try 
arbitration again. 

4. The SYM53C895 repeats arbitration until 
it wins control of the SCSI bus. When it 
has won, the Won Arbitration bit is set in 
the SSTATO register, bit 2. 

5. The SYM53C895 performs selection by 
asserting the following onto the SCSI bus: 
SSEL/, the target’s ID (stored in the SDID 
register), and the SYM53C895’s ID 
(stored in the SCID register). 

6. After a selection is complete, the Function 
Complete bit is set in the SISTO register, 
bit 6. 

7. If a selection time-out occurs, the Selection 
Time-Out bit is set in the SISTl register, 
bit 2. 

Bit 5 START (Start Sequence) 

When this bit is set, the SYM53C895 will start 
the arbitration sequence indicated by the Arbi¬ 
tration Mode bits. The Start Sequence bit is 
accessed directly in low-level mode; during 
SCSI SCRIPTS operations, this bit is con¬ 
trolled by the SCRIPTS processor. An arbitra¬ 
tion sequence should not be started if the 
connected (CON) bit in the SCNTLl register, 
bit 4, indicates that the SYM53C895 is already 
connected to the SCSI bus. This bit is auto¬ 
matically cleared when the arbitration 
sequence is complete. If a sequence is aborted, 
bit 4 in the SCNTLl register should be 
checked to verify that the SYM53C895 did not 
connect to the SCSI bus. 
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Bit 4 WATN (Select with SATN/ on a Start 
Sequence) 

When this bit is set and the SYM53C895 is in 
initiator mode, the SATN/ signal will be 
asserted during SYM53C895 selection of a 
SCSI target device. This is to inform the target 
that the SYM53C895 has a message to send. If 
a selection time-out occurs while attempting to 
select a target device, SATN/ will be deasserted 
at the same time SSEL/ is deasserted. When 
this bit is clear, the SATN/ signal will not be 
asserted during selection. When executing 
SCSI SCRIPTS, this bit is controlled by the 
SCRIPTS processor, but it may be set manu¬ 
ally in low level mode. 

Bit 3 EPC (Enable Parity Checking) 

When this bit is set, the SCSI data bus is 
checked for odd parity when data is received 
from the SCSI bus in either initiator or target 
mode. Parity is also checked as data goes from 
the SCSI FIFO to the DMA FIFO. If a parity 
error is detected, bit 0 of the SISTO register is 
set and an interrupt may be generated. 

If the SYM53C895 is operating in initiator 
mode and a parity error is detected, SATN/ 
can optionally be asserted, but the transfer 
continues until the target changes phase. When 
this bit is cleared, parity errors are not 
reported. 

Bit 2 Reserved 

Bit 1 AAP (Assert SATN/ on Parity Error) 

When this bit is set, the SYM53C895 automat¬ 
ically asserts the SATN/ signal upon detection 
of a parity error. SATN/ is only asserted in ini¬ 
tiator mode. The SATN/ signal is asserted 
before deasserting SACK/ during the byte 
transfer with the parity error. The Enable Par¬ 
ity Checking bit must also be set for the 
SYM53C895 to assert SATN/ in this manner. 
A parity error is detected on data received from 
the SCSI bus. 


If the Assert SATN/ on Parity Error bit is 
cleared or the Enable Parity Checking bit is 
cleared, SATN/ will not be automatically 
asserted on the SCSI bus when a parity error is 
received. 

Bit 0 TRG (Target Mode) 

This bit determines the default operating mode 
of the SYM53C895. The user must manually 
set target or initiator mode. This can be done 
using the SCRIPTS language (SETTARGET 
or CLEAR TARGET). When this bit is set, the 
chip is a target device by default. When this bit 
is cleared, the SYM53C895 is an initiator 
device by default. 

CAUTION: 

Writing this bit while not connected may cause the 
loss of a selection or reselection due to the chang¬ 
ing of target or initiator modes. 
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Register 01 (81) 

SCSI Control One (SCNTL1) 
Read/Write 


EXC 

ADB 

DHP 

CON 

RST 

AESP 

IARB 

SST 

7 

6 

5 

4 

3 

2 

1 

0 

Default>» 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7 EXC (Extra Clock Cycle of Data 
Setup) 

When this bit is set, an extra clock period of 
data setup is added to each SCSI send data 
transfer. The extra data setup time can provide 
additional system design margin, though it will 
affect the SCSI transfer rates. Clearing this bit 
disables the extra clock cycle of data setup 
time. Setting this bit only affects SCSI send 
operations. 

Bit 6 ADB (Assert SCSI Data Bus) 

When this bit is set, the SYM53C895 drives 
the contents of the SCSI Output Data Latch 
Register (SODL) onto the SCSI data bus. 
When the SYM53C895 is an initiator, the 
SCSI I/O signal must be inactive to assert the 
SODL contents onto the SCSI bus. When the 
SYM53C895 is a target, the SCSI I/O signal 
must be active for the SODL contents to be 
asserted onto the SCSI bus. The contents of 
the SODL register can be asserted at any time, 
even before the SYM53C895 is connected to 
the SCSI bus. This bit should be cleared when 
executing SCSI SCRIPTS. It is normally used 
only for diagnostics testing or operation in low 
level mode. 

Bit 5 DHP (Disable Halt on Parity Error 
or ATN) (Target Only) 

The DHP bit is only defined for target mode. 
When this bit is cleared, the SYM53C895 halts 
the SCSI data transfer when a parity error is 
detected or when the SATN/ signal is asserted. 
If SATN/ or a parity error is received in the 
middle of a data transfer, the SYM53C895 
may transfer up to three additional bytes before 
halting to synchronize between internal core 


cells. During synchronous operation, the 
SYM53C895 transfers data until there are no 
outstanding synchronous offsets. If the 
SYM53C895 is receiving data, any data resid¬ 
ing in the DMA FIFO is sent to memory 
before halting. 

When this bit is set, the SYM53C895 does not 
halt the SCSI transfer when SATN/ or a parity 
error is received. 

Bit 4 CON (Connected) 

This bit is automatically set any time the 
SYM53C895 is connected to the SCSI bus as 
an initiator or as a target. It is set after the 
SYM53C895 successfully completes arbitra¬ 
tion or when it has responded to a bus initiated 
selection or reselection. This bit is also set after 
the chip wins simple arbitration when operat¬ 
ing in low level mode. When this bit is clear, 
the SYM53C895 is not connected to the SCSI 
bus. 

The CPU can force a connected or discon¬ 
nected condition by setting or clearing this bit. 
This feature would be used primarily during 
loopback mode. 

Bit 3 RST (Assert SCSI RST/ Signal) 

Setting this bit asserts the SRST/ signal. The 
SRST/ output remains asserted until this bit is 
cleared. The 25 ps minimum assertion time 
defined in the SCSI specification must be 
timed out by the controlling microprocessor or 
a SCRIPTS loop. 

Bit 2 AESP (Assert Even SCSI Parity 
(force bad parity)) 

When this bit is set, the SYM53C895 asserts 
even parity. It forces a SCSI parity error on 
each byte sent to the SCSI bus from the 
SYM53C895. If parity checking is enabled, 
then the SYM53C895 checks data received for 
odd parity. This bit is used for diagnostic test¬ 
ing and should be clear for normal operation. 
It can be used to generate parity errors to test 
error handling functions. 
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Bit 1 IARB (Immediate Arbitration) 

Setting this bit causes the SCSI core to imme¬ 
diately begin arbitration once a Bus Free phase 
is detected following an expected SCSI discon¬ 
nect.This bit is useful for multi-threaded appli¬ 
cations. The ARB1-0 bits in SCNTLO should 
be set for full arbitration and selection before 
setting this bit. 

Arbitration will be re-tried until won. At that 
point, the SYM53C895 will hold BSY and 
SEL asserted, and wait for a select or reselect 
sequence to be requested. The Immediate 
Arbitration bit will be reset automatically when 
the selection or reselection sequence is com¬ 
pleted, or times out. 

An unexpected disconnect condition will clear 
IARB without attempting arbitration. See the 
SCSI Disconnect Unexpected bit (SCNTL2, 
bit 7) for more information on expected versus 
unexpected disconnects. 

An immediate arbitration sequence can be 
aborted. First, the Abort bit in the ISTAT reg¬ 
ister should be set. Then one of two things will 
eventually happen: 

1, The Won Arbitration bit (SSTATO bit 2) 
will be set. In this case, the Immediate 
Arbitration bit needs to be reset. This will 
complete the abort sequence and 
disconnect the SYM53C895 from the 
SCSI bus. If it is not acceptable to go to 
Bus Free phase immediately following the 
arbitration phase, a low level selection may 
be performed instead. 


BitO SST (Start SCSI Transfer) 

This bit is automatically set during SCRIPTS 
execution, and should not be used. It causes 
the SCSI core to begin a SCSI transfer, includ¬ 
ing SREQ/SACK handshaking. The determi¬ 
nation of whether the transfer is a send or 
receive is made according to the value written 
to the I/O bit in SOCL.This bit is self-reset¬ 
ting. It should not be set for low level opera¬ 
tion. 

CAUTION: 

Writing to this register while not connected may 
cause the loss of a selection/reselection by resetting 
the Connected bit. 


2. The abort will complete because the 

SYM53C895 loses arbitration. This can be 
detected by the Immediate Arbitration bit 
being cleared. The Lost Arbitration bit 
(SSTATO bit 3) should not be used to 
detect this condition. No further action 
needs to be taken in this case. 
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Register 02 (82) 

SCSI Control Two (SCNTL2) 
Read/Write 


SDU 

CHM 

SLPMD 

SLPHBEN 

WSS 

VUEO 

VUE1 

WSR 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7 SDU (SCSI Disconnect Unexpected) 

This bit is valid in initiator mode only. When 
this bit is set, the SCSI core is not expecting 
the SCSI bus to enter the Bus Free phase. If it 
does, an unexpected disconnect error will be 
generated (see the Unexpected Disconnect bit 
in the SISTO register, bit 2). During normal 
SCRIPTS mode operation, this bit is set auto¬ 
matically whenever the SCSI core is reselected, 
or successfully selects another SCSI device. 
The SDU bit should be reset with a register 
write (MOVE 0X00 TO SCNTL2) before the 
SCSI core expects a disconnect to occur, nor¬ 
mally prior to sending an Abort, Abort Tag, 
Bus Device Reset, Clear Queue or Release 
Recovery message, or before deasserting 
SACK/ after receiving a Disconnect command 
or Command Complete message. 

Bit 6 CHM (Chained Mode) 

This bit determines whether or not the SCSI 
core is programmed for chained SCSI mode. 
This bit is automatically set by the Chained 
Block Move (CHMOV) SCRIPTS instruction 
and is automatically cleared by the Block Move 
SCRIPTS instruction (MOVE). 

Chained mode is primarily used to transfer 
consecutive wide data blocks. Using chained 
mode facilitates partial receive transfers and 
allows correct partial send behavior. When this 
bit is set and a data transfer ends on an odd 
byte boundary, the SYM53C895 will store the 
last byte in the SCSI Wide Residue Data Regis¬ 
ter during a receive operation, or in the SCSI 
Output Data Latch register during a send 
operation.This byte will be combined with the 
first byte from the subsequent transfer so that a 
wide transfer can be completed. 


For more information, see the “Chained 
Mode” section in Chapter 2, “Functional 
Description.” 

Bit 5 SLPMD (SLPAR Mode Bit) 

If this bit is clear, the SLPAR register functions 
like the SYM53C825. If this bit is set, the 
SLPAR register reflects the high or low byte of 
the SLPAR word, depending on the state of 
SCNTL2 bit 4. It also allows a seed value to be 
written to the SLPAR register. 

Bit 4 SLPHBEN (SLPAR High Byte 
Enable) 

If this bit is clear, the low byte of the SLPAR 
word is present in the SLPAR register. If this 
bit is set, the high byte of the SLPAR word is 
present in the SLPAR register. 

Bit 3 WSS (Wide SCSI Send) 

When read, this bit returns the value of the 
Wide SCSI Send (WSS) flag. Asserting this bit 
will clear the WSS flag. This clearing function 
is self-resetting. 

When the WSS flag is high following a wide 
SCSI send operation, the SCSI core is holding 
a byte of “chain” data in the SODL register. 
This data will become the first low-order byte 
sent when married with a high-order byte dur¬ 
ing a subsequent data send transfer. 

Performing a SCSI receive operation will clear 
this bit. Also, performing any non-wide trans¬ 
fer will clear this bit. 

Bit 2 VUEO (Vendor Unique Enhance¬ 
ments bit 0) 

This bit is a read only value indicating whether 
the group code field in the SCSI instruction is 
standard or vendor unique. If reset, the bit 
indicates standard group codes; if set, the bit 
indicates vendor unique group codes. The 
value in this bit is reloaded at the beginning of 
all asynchronous target receives. The default 
for this bit is reset. 
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Bit 1 VUE1 (Vendor Unique Enhance¬ 
ments bit 1) 

This bit is used to disable the automatic byte 
count reload during Block Move instructions 
in the command phase. If this bit is reset, the 
device will reload the Block Move byte count if 
the first byte received is one of the standard 
group codes. If this bit is set, the device will 
not reload the Block Move byte count, regard¬ 
less of the group code. 

Bit 0 WSR (Wide SCSI Receive) 

When read, this bit returns the value of the 
Wide SCSI Receive (WSR) flag. Setting this 
bit clears the WSR flag. This clearing function 
is self-resetting. 

The WSR flag indicates that the SCSI core 
received data from the SCSI bus, detected a 
possible partial transfer at the end of a chained 
or non-chained block move command, and 
temporarily stored the high-order byte in the 
SWIDE register rather than passing the byte 
out the DMA channel.The hardware uses the 
WSR status flag to determine what behavior 
must occur at the start of the next data receive 
transfer. When the flag is set, the stored data in 
SWIDE may be “residue” data, valid data for a 
subsequent data transfer, or overrun data. The 
byte may be read as normal data by starting a 
data receive transfer. 

Performing a SCSI send operation will clear 
this bit. Also, performing any non-wide trans¬ 
fer will clear this bit. 


Register 03 (83) 

SCSI Control Three (SCNTL3) 
Read/Write 


ULTRA 

SCF2 

SCF1 

SCF0 

EWS 

CCF2 

CCF1 

CCFO 

7 

6 

5 

4 

3 

2 

1 

0 


Defaul 


t»> 


0 0 0 0 0 0 0 0 


Bit 7 ULTRA (Ultra Enable) 

Setting this bit enables Ultra SCSI or Ultra2 
SCSI synchronous transfer rates. The default 
value of this bit is O.This bit should remain 
cleared if the SYM53C895 is not operating in 
Ultra SCSI mode or faster. 

Note: set this bit to achieve Ultra SCSI transfer 
rates in legacy systems that use an 80 MHz 
clock. 

When this bit is set, the signal filtering period 
for SREQ/ and SACK/ automatically changes 
to 8 ns for Ultra2 SCSI or 15 ns for Ultra 
SCSI, regardless of the value of the Extend 
REQ/ACK Filtering bit in the STEST2 regis¬ 
ter. 

Bits 6-4 SCF2-0 (Synchronous Clock 
Conversion Factor) 

These bits select the factor by which the fre¬ 
quency of SCLK is divided before being pre¬ 
sented to the synchronous SCSI control logic. 
The bits are encoded as per Table 5-2. For syn¬ 
chronous receive, the output of this divider is 
always divided by 4 and that value determines 
the transfer rate. For example, if SCLK is 160 
MHz, and the SCF value is set to divide by 
one, then the maximum synchronous receive 
rate is 40 MHz((160/l)/4 = 40). 

For synchronous send, the output of this 
divider gets divided by the transfer period 
(XFERP) bits in the SCSI Transfer (SXFER) 
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register, and that value determines the transfer 
rate. For valid combinations of the SCF and 
XFERP, see Table 5-4 and Table 5-5. 


Table 5-2: Synchronous Clock Conversion 
Factor 


SCF2 

SCF1 

SCFO 

Factor Frequency 

0 

0 

0 

SCLK/3 

0 

0 

1 

SCLK/1 

0 

1 

0 

SCLK/1.5 

0 

1 

1 

SCLK/2 

1 

0 

0 

SCLK/3 

1 

0 

1 

SCLK/4 

1 

1 

0 

SCLK/6 

1 

1 

1 

SCLK/8 


Note: for additional information on how the 

synchronous transfer rate is determined, 
refer to Chapter 2. 


Bit 3 EWS (Enable Wide SCSI) 

When this bit is clear, all information transfer 
phases are assumed to be eight bits, transmit¬ 
ted on SD7-0/, SDPO/.When this bit is 
asserted, data transfers are done 16 bits at a 
time, with the least significant byte on SD7-0/, 
SDP/ and the most significant byte on 
SD15-8/, SDP1/. Command, Status, and Mes¬ 
sage phases are not affected by this bit. 

Clearing this bit will also clear the Wide SCSI 
Receive bit in the SCNTL2 register, which 
indicates the presence of a valid data byte in 
the SWIDE register. 


Table 5-3: Asynchronous Clock Conversion 
Factor 


CCF2 

CCF1 

CCFO 

SCSI Clock (MHz) 

0 

0 

0 

50.01-75 

0 

0 

1 

16.67-25 

0 

i 

0 

25.01-37.5 

0 

1 

1 

37.51-50 

1 

0 

0 

50.01-75 

1 

0 

1 

75.01-80.00 

1 

1 

0 

120 (not 
normally used) 

1 

1 

1 

160 (with clock qua¬ 
druplet and 40 MHz 
clock) 


Note: for additional information on how the 

synchronous transfer rate is determined, 
refer to Chapter 2, “Functional 
Description.” 


Bits 2-0 CCF2-0 (Clock Conversion Factor) 

These bits select the frequency of the SC L K 
for asynchronous SCSI operations.The bits are 
encoded as per the following table. 


SYM53C895 Data Manual 


5-11 



Operating Registers 


Register 04 (84) 

SCSI Chip ID (SCID) 
Read/Write 


RES 

RRE 

SRE 

RES 

ENC3 

ENC2 

ENC1 

ENCO 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

X 0 

0 

X 

0 

0 

0 

0 


Bit 7 Reserved 

Bit 6 RRE (Enable Response to 

Reselection) 

When this bit is set, the SYM53C895 is 
enabled to respond to bus-initiated reselection 
at the chip ID in the RESPIDO and RESPID1 
registers. Note that the SYM53C895 will not 
automatically reconfigure itself to initiator 
mode as a result of being reselected. 

Bit 5 SRE (Enable Response to Selection) 

When this bit is set, the SYM53C895 is able to 
respond to bus-initiated selection at the chip 
ID in the RESPIDO and RESPIDl registers. 
Note that the SYM53C895 will not automati¬ 
cally reconfigure itself to target mode as a 
result of being selected. 

Bit 4 Reserved 

Bits 3-0 Encoded Chip SCSI ID, bits 3-0 

These bits are used to store the SYM53C895 
encoded SCSI ID. This is the ID which the 
chip will assert when arbitrating for the SCSI 
bus. The IDs that the SYM53C895 will 
respond to when being selected or reselected 
are configured in the RESPIDO and RESPIDl 
registers. The priority of the 16 possible IDs, in 
descending order is: 

Highest Lowest 

7 6 5 4 3 2 1 0 15 14 13 12 11 10 9 8 


Register 05 (85) 

SCSI Transfer (SXFER) 
Read/Write 


TP2 

msm 


M04 

M03 

M02 



7 

mm 

■i 

4 

3 

2 



Default»> 

0 0 

0 

0 

0 

0 

0 

0 


Note: when using Table Indirect I/O commands, 
bits 7-0 of this register will be loaded from 
the I/O data structure. 

Note: for additional information on how the 

synchronous transfer rate is determined, 
refer to Chapter 2, “Functional 
Description.” 

Bits 7-5 TP2-0 (SCSI Synchronous Transfer 
Period) 

These bits determine the SCSI synchronous 
transfer period (XFERP) used by the 
SYM53C895 when sending synchronous SCSI 
data in either initiator or target mode. These 
bits control the programmable dividers in the 
chip. 

Note: for Ultra SCSI transfers, the ideal transfer 
period is 4, and 5 is acceptable. Setting the 
transfer period to a value greater than 5 is 
not recommended. 


TP2 

TP1 

TPO 

XFERP 

0 

0 

0 

4 

0 

0 

1 

5 

0 

1 

0 

6 

0 

1 

1 

7 

1 

0 

0 

8 

1 

0 

1 

9 

1 

1 

0 

10 

1 

1 

1 

11 


Use the following formula to calculate the synchro¬ 
nous send and receive rates. Table 5-4 and 
Table 5-5 show examples of possible bit combina¬ 
tions. 
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Synchronous Send Rate = (SCLK/SCF)/XFERP 
Synchronous Receive Rate = (SCLK/SCF) / 4 

Key: 

SCLK = SCLK 

SCF = Synchronous Clock Conversion Factor, SCNTL3 bits 6-4 
XFERP = Transfer period, SXFER register bits 7-5 


Table 5-4: Examples of Synchronous Transfer Periods and Rates for SCSI-1 


SCLK (MHz) 

SCF(SCNTL3 
bits 6-4) 

XFERP (SXFER 
bits 7-5) 

Sync Send 
Rate (MB/s) 

Sync Send 
Period (ns) 

Sync Receive 
Rate (MB/s) 

Synch 

Receive 

Period (ns) 

80 

+ 4 

4 

5 

200 

5 

200 

80 

+ 4 

5 

4 

250 

5 

200 

66.67 

4-3 

4 

5.55 

180 

5.55 

180 

66.67 

4-3 

5 

4.44 

225 

5.55 

180 

50 

4-2 

4 

6.25 

160 

6.25 

160 

50 

4-2 

5 

5 

200 

6.25 

160 

40 

4-2 

4 

5 

200 

5 

200 

37.50 

4 - 1.5 

4 

6.25 

160 

6.25 

160 

33.33 

-H 1.5 

4 

5.55 

180 

5.55 

180 

25 

4 - 1 

4 

6.25 

160 

6.25 

160 

20 

4 - 1 

4 

5 

200 

5 

200 

16.67 

4 - 1 

4 

4.17 

240 

4.17 

240 

Table 5-5: 

Example Synchronous Transfer Periods and Rates for Fast SCSI, Ultra SCSI 

SCSI 

, and Ultra2 

SCLK (MHz) 

SCF(SCNTL3 
bits 6-4) 

XFERP(SXFER 
bits 7-5) 

Sync Send 
Rate (MB/s) 

Sync Send 
Period (ns) 

Sync Receive 
Rate (MB/s) 

Synch 

Receive 

Period (ns) 

160 

4 - 1 

4 

40 

25 

40 

25 

80 

4 - 1 

4 

20 

50 

20 

50 

80 

4-2 

4 

10 

100 

10 

100 

66.67 

4 - 1.5 

4 

li.ii 

90 

li.ii 

90 

66.67 

4 - 1 

5 

8.88 

112.5 

ii.il 

90 

50 

4 - 1 

4 

12.5 

80 

12.5 

80 

50 

4 - 1 

5 

10 

100 

12.5 

80 

40 

4 - 1 

4 

10 

100 

10 

100 

37.50 

4 - 1 

4 

9.375 

106.67 

9.375 

106.67 

33.33 

4 - 1 

4 

8.33 

120 

8.33 

120 

25 

4 1 

4 

6.25 

160 

6.25 

160 

20 

4 1 

4 

5 

200 

5 

200 

16.67 

+ 1 

4 

4.17 

240 

4.17 

240 
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Bits 4-0 MO4-MO0 (Max SCSI Synchronous 
Offset) 

These bits describe the maximum SCSI syn¬ 
chronous offset used by the SYM53C895 
when transferring synchronous SCSI data in 
either initiator or target mode. The following 
table describes the possible combinations and 
their relationship to the synchronous data off¬ 
set used by the SYM53C895.These bits deter¬ 
mine the SYM53C895’s method of transfer for 
Data In and Data Out phases only; all other 
information transfers will occur asynchro¬ 
nously. 


Table 5-6: SCSI Synchronous Offset Values 


M04 

M03 

M02 

M01 

MOO 

Synchronous 

Offset 

0 

0 

0 

0 

0 

O-Asynchronous 

0 

0 

0 

0 

1 

1 

0 

0 

0 

1 

0 

2 

0 

0 

0 

1 

1 

3 

0 

0 

1 

0 

0 

4 

0 

0 

1 

0 

1 

5 

0 

0 

1 

1 

0 

6 

0 

0 

1 

1 

1 

7 

0 

1 

0 

0 

0 

8 

0 

1 

0 

0 

1 

9 

0 

1 

0 

1 

0 

10 

0 

1 

0 

1 

1 

11 

0 

1 

1 

0 

0 

12 

0 

1 

1 

0 

1 

13 

0 

1 

1 

1 

0 

14 

0 

1 

1 

1 

1 

15 

1 

0 

0 

0 

0 

16 

1 

0 

0 

0 

1 

17 

1 

0 

0 

1 

0 

18 

1 

0 

0 

1 

1 

19 

1 

0 

1 

0 

0 

20 

1 

0 

1 

0 

1 

21 

1 

0 

1 

1 

0 

22 

1 

0 

1 

1 

1 

23 

1 

1 

0 

0 

0 

24 

1 

1 

0 

0 

1 

25 

1 

1 

0 

1 

0 

26 

1 

1 

0 

1 

1 

27 

1 

1 

1 

0 

0 

28 

1 

1 

1 

0 

1 

29 

1 

1 

1 

1 

0 

30 

1 

1 

1 

1 

1 

31 


5-14 


SYM53C895 Data Manual 



Operating Registers 


Register 06 (86) Register 07 (87) 

SCSI Destination ID (SDID) General Purpose (GPREG) 

Read/Write Read/Write 


RES 

RES 

RES 


ENC3 

ENC2 

ENC1 

ENCO 

7 

6 

5 

4 

3 

2 

1 

0 

Defau lt»> 

X X 

X 

X 

0 

0 

0 

0 


RES 

RES 

RES 

GPI04 

GPI03 

GPI02 

GPI01 

GPIOO 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

X X 

X 

0 

X 

X 

X 

X 


Bits 7-4 Reserved 

Bits 3-0 Encoded Destination SCSI ID 

Writing these bits sets the SCSI ID of the 
intended initiator or target during SCSI rese¬ 
lection or selection phases, respectively. When 
executing SCRIPTS, the SCRIPTS processor 
writes the destination SCSI ID to this register. 
The SCSI ID is defined by the user in a 
SCRIPTS SELECT or RESELECT instruc¬ 
tion. The value written should be the binary- 
encoded ID value. The priority of the 16 possi¬ 
ble IDs, in descending order, is: 

Highest Lowest 

7 6 5 4 3 2 1 0 15 14 13 12 11 0 9 8 


Bits 7-5 Reserved 

Bits 4-0 GPIO4-GPIO0 (General Purpose) 

These bits can be programmed through the 
GPCNTL Register to become inputs, outputs 
or to perform special functions. As an output, 
these pins can be used to enable or disable 
external terminators. These signals can also be 
programmed as live inputs and sensed through 
a SCRIPTS Register to Register Move Instruc¬ 
tion. GPIO(3-0) default as inputs and GPI04 
defaults as an output pin. 

GPI04 can be used to enable or disable Vpp, 
the 12-volt power supply to the external flash 
memory. This bit powers up with the power to 
the external memory disabled. 

Symbios Logic Use of GPIO Pins 

The software used with Symbios Logic PCI to 
SCSI host adapters uses the GPI04 pin in the 
process of flashing a new ROM. 

Symbios Logic software uses the GPIOO pin to 
toggle SCSI device LEDs, turning on the LED 
whenever the SYM53C895 is on the SCSI bus. 
Symbios Logic software drives this pin low to 
turn on the LED, or drives it high to turn off 
the LED. 

Symbios Logic software uses the GPIO 1-0 
pins to support serial EEPROM access. When 
serial EEPROM access is enabled, GPIOl is 
used as a clock and GPIOO is used as data. 
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Register 08 (88) 

SCSI First Byte Received (SFBR) 
Read/Write 


1B7 

1B6 

1B5 

1B4 

1B3 

1B2 

1B1 

1B0 

7 

6 

5 

4 

3 

2 

1 

0 

Defau lt»> 

0 0 

0 

0 

0 

0 

0 

0 


This register contains the first byte received in any 
asynchronous information transfer phase. For ex¬ 
ample, when the SYM53C895 is operating in initi¬ 
ator mode, this register contains the first byte 
received in the Message In, Status, and Data In 
phases. 

When a Block Move instruction is executed for a 
particular phase, the first byte received is stored in 
this register— even if the present phase is the same 
as the last phase. The first byte received value for a 
particular input phase is not valid until after a 
MOVE instruction is executed. 

This register is also the accumulator for register 
read-modify-writes with the SFBR as the destina¬ 
tion. This allows bit testing after an operation. 

The SFBR is not writable via the CPU, and there¬ 
fore not by a Memory Move. The Load instruction 
may not be used to write to this register. However, 
it can be loaded via SCRIPTS Read/Write opera¬ 
tions. To load the SFBR with a byte stored in sys¬ 
tem memory, the byte must first be moved to an 
intermediate SYM53C895 register (such as the 
SCRATCH register), and then to the SFBR. 

This register will also contain the state of the lower 
eight bits of the SCSI data bus during the selection 
phase if the COM bit in the DCNTL register is 
clear. 


Register 09 (89) 

SCSI Output Control Latch (SOCL) 
Read /Write 



■f.W 

BSY 

SEL 


■Mil 

C/D 

I/O 

'HI 

m 

5 

4 

mm 

m 

1 

0 

Default»> 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7 REQ(Assert SCSI REQ/ Signal) 

Bit 6 ACK(Assert SCSI ACK/ Signal) 

Bit 5 BSY(Assert SCSI BSY/ Signal) 

Bit 4 SEL(Assert SCSI SEL/ Signal) 

Bit 3 ATN(Assert SCSI ATN/Signal) 

Bit 2 MSG(Assert SCSI MSG/ Signal) 

Bit 1 C/D (Assert SCSI C_D/ Signal) 

Bit 0 I/O (Assert SCSI I_0/ Signal) 

This register is used primarily for diagnostic testing 
or programmed I/O operation. It is controlled by 
the SCRIPTS processor when executing SCSI 
SCRIPTS. SOCL should only be used when trans¬ 
ferring data via programmed I/O. Some bits are set 
(1) or reset (0) when executing SCSI SCRIPTS. 
Do not write to the register once the SYM53C895 
starts executing normal SCSI SCRIPTS. 
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Register OA (8A) 

SCSI Selector ID (SSID) 
Read Only 


VAL 

RES 

RES 

RES 

ENID3 

ENID2 

EN1D1 

ENIDO 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

0 X 

X 

X 

0 

0 

0 

0 


Register OB (8B) 

SCSI Bus Control Lines (SBCL) 
Read Only 


KM 

■MM 


K3H 



C/D 

I/O 

£■ 

m 

wM 

mm 

m 

mu 

1 

0 

Default»> 

X X 

X 

X 

X 

X 

X 

X 


Bit 7 VAL (SCSI Valid) 

IfVAL is asserted, the two SCSI IDs were 
detected on the bus during a bus-initiated 
selection or reselection, and the encoded desti¬ 
nation SCSI ID bits below are valid. IfVAL is 
deasserted, only one ID was present and the 
contents of the encoded destination ID are 
meaningless. 

Bits 6-4 Reserved 

Bits 3-0 Encoded Destination SCSI ID 

Reading the SSID register immediately after 
the SYM53C895 has been selected or rese¬ 
lected returns the binary-encoded SCSI ID of 
the device that performed the operation. These 
bits are invalid for targets that are selected 
under the single initiator option of the SCSI-1 
specification. This condition can be detected 
by examining the VAL bit above. 


Bit 7 REQ (SREQ/ Status) 

Bit 6 ACK (SACK/ Status) 

Bit 5 BSY (SBSY/ Status) 

Bit 4 SEL (SSEL/ Status) 

Bit 3 ATN (SATN/ Status) 

Bit 2 MSG (SMSG/ Status) 

Bit 1 C/D (SC_D/ Status) 

Bit 0 I/O (SI_0/ Status) 

When read, this register returns the SCSI control 
line status. A bit will be set when the corresponding 
SCSI control line is asserted. These bits are not 
latched; they are a true representation of what is on 
the SCSI bus at the time the register is read. The re¬ 
sulting read data is synchronized before being pre¬ 
sented to the PCI bus to prevent parity errors from 
being passed to the system. This register can be 
used for diagnostics testing or operation in low level 
mode. 
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Register OC (8C) 

DMA Status (DSTAT) 
Read Only 


DFE 

MDPE 

BF 

ABRT 

SSI 

SIR 

RES 

IID 

7 

6 

5 

4 

3 

2 

1 

0 

Detail lt»> 

1 0 

0 

0 

0 

0 

X 

0 


Reading this register will clear any bits that are set 
at the time the register is read, but will not neces¬ 
sarily clear the register because additional inter¬ 
rupts may be pending (the SYM53C895 stacks 
interrupts). The DIP bit in the ISTAT register will 
also be cleared. DMA interrupt conditions may be 
individually masked through the DIEN register. 

When performing consecutive 8-bit reads of the 
DSTAT, SISTO and SISTl registers (in any or¬ 
der), insert a delay equivalent to 12 CLK periods 
between the reads to ensure that the interrupts clear 
properly. See Chapter 2, “Functional Description,” 
for more information on interrupts. 

Bit 7 DFE (DMA FIFO Empty) 

This status bit is set when the DMA FIFO is 
empty. It may be used to determine if any data 
resides in the FIFO when an error occurs and 
an interrupt is generated. This bit is a pure sta¬ 
tus bit and will not cause an interrupt. 

Bit 6 MDPE (Master Data Parity Error) 

This bit is set when the SYM53C895 as a mas¬ 
ter detects a data parity error, or a target device 
signals a parity error during a data phase. This 
bit is completely disabled by the Master Parity 
Error Enable bit (bit 3 of CTEST4). 

Bit 5 BF (Bus Fault) 

This bit is set when a PCI bus fault condition 
is detected. A PCI bus fault can only occur 
when the SYM53C895 is bus master, and is 
defined as a cycle that ends with a Bad Address 
or Target Abort Condition. 


Bit 4 ABRT (Aborted) 

This bit is set when an abort condition occurs. 
An abort condition occurs when a software 
abort command is issued by setting bit 7 of the 
ISTAT register. 

Bit 3 SSI (Single Step Interrupt) 

If the Single-Step Mode bit in the DCNTL 
register is set, this bit will be set and an inter¬ 
rupt generated after successful execution of 
each SCRIPTS instruction. 

Bit 2 SIR (SCRIPTS Interrupt 

Instruction Received) 

This status bit is set whenever an Interrupt 
instruction is evaluated as true. 

Bit 1 Reserved 

Bit 0 IID (Illegal Instruction Detected) 

This status bit will be set any time an illegal or 
reserved instruction op code is detected, 
whether the SYM53C895 is operating in sin¬ 
gle-step mode or automatically executing SCSI 
SCRIPTS. Any of the following conditions 
during instruction execution will also cause 
this bit to be set: 

1. The SYM53C895 is executing aWait 
Disconnect instruction and the SCSI REQ 
line is asserted without a disconnect 
occurring. 

2. A Block Move instruction is executed with 
OOOOOOh loaded into the DBC register, 
indicating that zero bytes are to be moved. 

3. During a Transfer Control instruction, the 
Compare Data (bit 18) and Compare 
Phase (bit 17) bits are set in the DBC 
register while the SYM53C895 is in target 
mode. 

4. During a Transfer Control instruction, the 
Carry Test bit (bit 21) is set and either the 
Compare Data (bit 18) or Compare Phase 
(bit 17) bit is set. 
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5. A Transfer Control instruction is executed 
with the reserved bit 22 set. 

6. A Transfer Control instruction is executed 
with the Wait for Valid phase bit (bit 16) set 
while the chip is in target mode. 

7. A Load/Store instruction is issued with the 
memory address mapped to the operating 
registers of the chip, not including ROM or 
RAM. 

8. A Load/Store instruction is issued when 
the register address is not aligned with the 
memory address 

9. A Load/Store instruction is issued with bit 
5 in the DCMD register clear or bits 3 or 2 
set. 

10. A Load/Store instruction when the count 
value in the DBC register is not set at 1 to 
4. 

11. A Load/Store instruction attempts to cross 
a dword boundary. 

12. A Memory Move instruction is executed 
with one of the reserved bits in the DCMD 
register set. 

13. A Memory Move instruction is executed 
with the source and destination addresses 
not byte-aligned. 


Register OD (8D) 

SCSI Status Zero (SSTATO) 
Read Only 


ILF 

ORF 

OLF 

AIP 

LOA 

WOA 

RST 

SDPO/ 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7 ILF (SIDL Least Significant Byte 
Full) 

This bit is set when the least significant byte in 
the SCSI Input Data Latch register (SIDL) 
contains data. Data is transferred from the 
SCSI bus to the SCSI Input Data Latch regis¬ 
ter before being sent to the DMA FIFO and 
then to the host bus. The SIDL register con¬ 
tains SCSI data received asynchronously. Syn¬ 
chronous data received does not flow through 
this register. 

Bit 6 ORF (SODR Least Significant Byte 
Full) 

This bit is set when the least significant byte in 
the SCSI Output Data Register (SODR, a hid¬ 
den buffer register which is not accessible) 
contains data. The SODR register is used by 
the SCSI logic as a second storage register 
when sending data synchronously. It cannot be 
read or written by the user. This bit can be 
used to determine how many bytes reside in 
the chip when an error occurs. 

Bit 5 OLF (SODL Least Significant Byte 
Full) 

This bit is set when the least significant byte in 
the SCSI Output Data Latch (SODL) contains 
data. The SODL register is the interface 
between the DMA logic and the SCSI bus. In 
synchronous mode, data is transferred from 
the host bus to the SODL register, and then to 
the SCSI Output Data Register (SODR, a hid¬ 
den buffer register which is not accessible) 
before being sent to the SCSI bus. In asyn¬ 
chronous mode, data is transferred from the 
host bus to the SODL register, and then to the 
SCSI bus. The SODR buffer register is not 
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used for asynchronous transfers.This bit can 
be used to determine how many bytes reside in 
the chip when an error occurs. 

Bit 4 AIP (Arbitration in Progress) 

Arbitration in Progress (AIP = 1) indicates that 
the SYM53C895 has detected a Bus Free con¬ 
dition, asserted BSY, and asserted its SCSI ID 
onto the SCSI bus. 

Bit 3 LOA (Lost Arbitration) 

When set, LOA indicates that the 
SYM53C895 has detected a bus free condi¬ 
tion, arbitrated for the SCSI bus, and lost arbi¬ 
tration due to another SCSI device asserting 
the SEL/ signal. 


Register OE (8E) 

SCSI Status One (SSTAT1) 
Read Only 


FF3 

FF2 

FF1 

o 

U_ 

LI- 

SDPOL 

MSG 

C/D 

1/0 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

0 0 

0 

0 

X 

X 

X 

X 


Bits 7-4 FF3-FF0 (FIFO Hags) 

These four bits, along with SSTAT2 bit 4, 
define the number of bytes or words that cur¬ 
rently reside in the SYM53C895’s SCSI syn¬ 
chronous data FIFO. These bits are not latched 
and they will change as data moves through the 
FIFO. 


Bit 2 WOA (Won Arbitration) 

When set, WOA indicates that the 
SYM53C895 has detected a Bus Free condi¬ 
tion, arbitrated for the SCSI bus and won arbi¬ 
tration. The arbitration mode selected in the 
SCNTLO register must be full arbitration and 
selection for this bit to be set. 

Bit 1 RST/ (SCSI RST/ Signal) 

This bit reports the current status of the SCSI 
RST/ signal, and the RST signal (bit 6) in the 
ISTAT register. This bit is not latched and may 
be changing when read. 

Bit 0 SDPO/ (SCSI SDPO/ Parity Signal) 

This bit represents the active high current sta¬ 
tus of the SCSI SDPO/ parity signal. This signal 
is not latched and may be changing as it is 
read. 


Table 5-7: FIFO Flags BitValues 


FF4 

(SSTAT2 
bit 4) 


0 

0 

0 

0 

0 

0 

0 

0 

0 

0 

0 

0 

0 

0 

0 

0 

1 

1 

1 

1 


FF3 FF2 FF1 


0 0 0 
0 0 0 
0 0 1 
0 0 1 
0 1 0 
0 1 0 
0 1 1 
0 1 1 
1 0 0 
1 0 0 
1 0 1 
1 0 1 
1 1 0 
1 1 0 
1 1 1 
1 1 1 
0 0 0 
0 0 0 
0 0 1 
0 0 1 


FFO 


0 

1 

0 

1 

0 

1 

0 

1 

0 

1 

0 

1 

0 

1 

0 

1 

0 

1 

0 

1 


Bytes or 
Words in 
the SCSI 
FIFO 


0 

1 

2 

3 

4 

5 

6 

7 

8 

9 

10 
11 
12 

13 

14 

15 

16 

17 

18 
19 
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Table 5-7: FIFO Flags BitValues (Continued) 


FF4 

(SSTAT2 
bit 4) 

FF3 

FF2 

FF1 

FFO 

Bytes or 
Words in 
the SCSI 
FIFO 

1 

0 

1 

0 

0 

20 

1 

0 

1 

0 

1 

21 

1 

0 

1 

1 

0 

22 

1 

0 

1 

1 

1 

23 

1 

1 

0 

0 

0 

24 

1 

1 

0 

0 

1 

25 

1 

1 

0 

1 

0 

26 

1 

1 

0 

1 

1 

27 

1 

1 

1 

0 

0 

28 

1 

1 

1 

0 

1 

29 

1 

1 

1 

1 

0 

30 

1 

1 

1 

1 

1 

31 


Bit 3 SDPOL (Latched SCSI Parity) 

This bit reflects the SCSI parity signal 
(SDPO/), corresponding to the data latched in 
the SCSI Input Data Latch register (SIDL). It 
changes when a new byte is latched into the 
least significant byte of the SIDL register. This 
bit is active high, in other words, it is set when 
the parity signal is active. 

Bit 2 MSG (SCSI MSG/ Signal) 

Bit 1 C/D (SCSI C_D/ Signal) 

Bit 0 I/O (SCSI I_0/ Signal) 

These SCSI phase status bits are latched on the as¬ 
serting edge of SREQ/ when operating in either ini¬ 
tiator or target mode. These bits are set when the 
corresponding signal is active. They are useful 
when operating in low level mode. 


Register OF (8F) 

SCSI Status Two (SSTAT2) 
(Read Only) 


ILF1 

0RF1 

0LF1 

FF4 

SPL1 

DM 

LDSC 

SDP1 

7 

6 

5 

4 

3 

2 

1 

0 

Default>» 

0 0 

0 

0 

X 

X 

1 

X 


Bit 7 ILF1 (SIDL Most Significant Byte 
Full) 

This bit is set when the most significant byte in 
the SCSI Input Data Latch register (SIDL) 
contains data. Data is transferred from the 
SCSI bus to the SCSI Input Data Latch regis¬ 
ter before being sent to the DMA. FIFO and 
then to the host bus.The SIDL register con¬ 
tains SCSI data received asynchronously. Syn¬ 
chronous data received does not flow through 
this register. 

Bit 6 ORF1 (SODR Most Significant Byte 
Full) 

This bit is set when the most significant byte in 
the SCSI Output Data Register (SODR, a hid¬ 
den buffer register which is not accessible) 
contains data. The SODR register is used by 
the SCSI logic as a second storage register 
when sending data synchronously. It is not 
accessible to the user. This bit can be used to 
determine how many bytes reside in the chip 
when an error occurs. 

Bit 5 OLFl (SODL Most Significant Byte 
Full) 

This bit is set when the most significant byte in 
the SCSI Output Data Latch (SODL) contains 
data. The SODL register is the interface 
between the DMA logic and the SCSI bus. In 
synchronous mode, data is transferred from 
the host bus to the SODL register, and then to 
the SCSI Output Data Register (SODR, a hid¬ 
den buffer register which is not accessible) 
before being sent to the SCSI bus. In asyn¬ 
chronous mode, data is transferred from the 
host bus to the SODL register, and then to the 
SCSI bus. The SODR buffer register is not 
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used for asynchronous transfers. This bit can 
be used to determine how many bytes reside in 
the chip when an error occurs. 

Bit 4 FF4 (FIFO Flags bit 4) 

This is the most significant bit in the SCSI 
FIFO Flags field, with the rest of the bits in 
SSTAT1. For a complete description of this 
field, see the definition for SSTAT1 bits 7-4. 

Bit 3 SPLl (Latched SCSI parity for 
SD15-8) 

This active high bit reflects the SCSI odd par¬ 
ity signal corresponding to the data latched 
into the most significant byte in the SIDL reg¬ 
ister. 

Bit 2 DM (DIFFSENS Mismatch) 

This bit is set when the DIFFSENS pin detects 
a single-ended or LVD SCSI operating voltage 
level while the SYM53C895 is operating in 
high-power differential mode (by setting the 
DIF bit in the STEST2 register). If this bit is 
reset, the DIFFSENS value matches the DIF 
bit setting. 

Bit 1 LDSC (Last Disconnect) 

Used in conjunction with the Connected 
(CON) bit in SCNTL1, this status bit allows 
the user to detect the case in which a target 
device disconnects, and then another SCSI 
device selects or reselects, the SYM53C895. If 
the Connected bit is asserted and the LDSC 
bit is asserted, a disconnect has occurred. This 
bit is set when the Connected bit in SCNTLl 
is cleared.This bit is cleared when a Block 
Move instruction is executed while the Con¬ 
nected bit in SCNTLl is set. 

Bit 0 SDPl (SCSI SDP1 Signal) 

This bit represents the active-high current state 
of the SCSI SDPl parity signal. It is unlatched 
and may be changing as it is read. 


Registers 10-13 (90-93) 

Data Structure Address (DSA) 

Read/Write 

This 32-bit register contains the base address used 
for all table indirect calculations. The DSA register 
is usually loaded prior to starting an I/O, but it is 
possible for a SCRIPTS Memory Move to load the 
DSA during the I/O. 

During any Memory-to-Memory Move operation, 
the contents of this register are preserved. The 
power-up value of this register is indeterminate. 
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Register 14 (94) 
Interrupt Status (ISTAT) 
(Read/Write) 


ABRT 

SRST 

SIGP 

SEM 

CON 

INTF 

SIP 

DIP 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

0 0 

0 

0 

0 

0 

0 

0 


This is the only register that can be accessed by the 
host CPU while the SYM53C895 is executing 
SCRIPTS (without interfering in the operation of 
the SYM53C895). It may be used to poll for inter¬ 
rupts if hardware interrupts are disabled. There 
may be stacked interrupts pending; read this regis¬ 
ter after servicing an interrupt to check for stacked 
interrupts. For more information on interrupt han¬ 
dling refer to Chapter 2, “Functional Description.” 

Bit 7 ABRT (Abort Operation) 

Setting this bit aborts the current operation 
being executed by the SYM53C895. If this bit 
is set and an interrupt is received, reset this bit 
before reading the DSTAT register to prevent 
further aborted interrupts from being gener¬ 
ated. The sequence to abort any operation is: 

1. Set this bit. 

2. Wait for an interrupt. 

3. Read the ISTAT register. 

4. If the SCSI Interrupt Pending bit is set, 
then read the SISTO or SIST1 register to 
determine the cause of the SCSI Interrupt 
and go back to Step 2. 

5. If the SCSI Interrupt Pending bit is clear, 
and the DMA Interrupt Pending bit is set, 
then write OOh value to this register. 

6. Read the DSTAT register to verify the 
aborted interrupt and to see if any other 
interrupting conditions have occurred. 

Bit 6 SRST (Software Reset) 

Setting this bit resets the SYM53C895. All 
operating registers are cleared to their respec¬ 
tive default values and all SCSI signals are 
deasserted. Setting this bit does not cause the 
SCSI RST/ signal to be asserted.This reset will 


not clear the 53C700 Compatibility bit or any 
of the PCI configuration registers. This bit is 
not self-clearing; it must be cleared to clear the 
reset condition (a hardware reset will also clear 
this bit). 

Bit 5 SIGP (Signal Process) 

SIGP is a R/W bit that can be written at any 
time, and polled and reset via CTEST2.The 
SIGP bit can be used in various ways to pass a 
flag to or from a running SCRIPTS instruc¬ 
tion. 

The only SCRIPTS instruction directly 
affected by the SIGP bit is Wait For Selection/ 
Reselection. Setting this bit causes that 
instruction to jump to the alternate address 
immediately. The instructions at the alternate 
jump address should check the status of SIGP 
to determine the cause of the jump. The SIGP 
bit may be used at any time and is not 
restricted to the wait for selection/ reselection 
condition. 

Bit 4 SEM (Semaphore) 

This bit can be set by the SCRIPTS processor 
using a SCRIPTS register write instruction. 
The bit may also be set by an external proces¬ 
sor while the SYM53C895 is executing a 
SCRIPTS operation. This bit enables the 
SYM53C895 to notify an external processor of 
a predefined condition while SCRIPTS are 
running. The external processor may also 
notify the SYM53C895 of a predefined condi¬ 
tion and the SCRIPTS processor may take 
action while SCRIPTS are executing. 

Bit 3 CON (Connected) 

This bit is automatically set any time the 
SYM53C895 is connected to the SCSI bus as 
an initiator or as a target. It will be set after 
successfully completing selection or when the 
SYM53C895 has responded to a bus-initiated 
selection or reselection. It will also be set after 
the SYM53C895 wins arbitration when oper¬ 
ating in low level mode. When this bit is clear, 
the SYM53C895 is not connected to the SCSI 
bus. 
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Bit 2 INTF (Interrupt on the Fly) 

This bit is asserted by an INTFLY instruction 
during SCRIPTS execution. SCRIPTS pro¬ 
grams will not halt when the interrupt occurs. 
This bit can be used to notify a service routine, 
running on the main processor while the 
SCRIPTS processor is still executing a 
SCRIPTS program. If this bit is set, when the 
ISTAT register is read it will not automatically 
be cleared. To clear this bit, it must be written 
to a one. The reset operation is self-clearing. 

Note: if the INTF bit is set but SIP or DIP is not 
set, do not attempt to read the other chip 
status registers. An interrupt-on-the-fly 
interrupt must be cleared before servicing 
any other interrupts indicated by SIP or 
DIP. 

Note: this bit must be written to one in order to 
clear it after it has been set. 

Bit 1 SIP (SCSI Interrupt Pending) 

This status bit is set when an interrupt condi¬ 
tion is detected in the SCSI portion of the 
SYM53C895.The following conditions will 
cause a SCSI interrupt to occur: 

■ A phase mismatch (initiator mode) or 
SATN/ becomes active (target mode) 

■ An arbitration sequence completes 

■ A selection or reselection time-out occurs 

■ The SYM53C895 was selected 

■ The SYM53C895 was reselected 

■ A SCSI gross error occurs 

■ An unexpected disconnect occurs 

■ A SCSI reset occurs 

■ A parity error is detected 

■ The handshake-to-handshake timer is 
expired 

■ The general purpose timer is expired 

■ A SCSI bus mode change is detected 

To determine exactly which condition(s) 
caused the interrupt, read the SISTO and 
SISTl registers. 


Bit 0 DIP (DMA Interrupt Pending) 

This status bit is set when an interrupt condi¬ 
tion is detected in the DMA portion of the 
SYM53C895.The following conditions will 
cause a DMA interrupt to occur: 

■ A PCI parity error is detected 

■ A bus fault is detected 

■ An abort condition is detected 

■ A SCRIPTS instruction is executed in 
single-step mode 

■ A SCRIPTS interrupt instruction is 
executed 

■ An illegal instruction is detected. 

To determine exactly which condition (s) 
caused the interrupt, read the DSTAT register. 
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Register 18 (98) 

Chip Test Zero (CTESTO) 

Read/Write 

This was a general purpose read/write register in 
previous SYM53C8XX family chips. Although it is 
still a read/write register, Symbios Logic reserves 
the right to use these bits for future 53C8XX family 
enhancements. 


Register 19 (99) 

Chip Test One (CTEST1) 
Read Only 


FMT3 

FMT2 

FMT1 

FMTO 

FFL3 

FFL2 

FFL1 

FFLO 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

1 1 

1 

1 

0 

0 

0 

0 


Bits 7-4 FMT3-0 (Byte Empty in DMA 
FIFO) 

These bits identify the bottom bytes in the 
DMA FIFO that are empty. Each bit corre¬ 
sponds to a byte lane in the DMA FIFO. For 
example, if byte lane three is empty, then 
FMT3 will be set. Since the FMT flags indi¬ 
cate the status of bytes at the bottom of the 
FIFO, if all FMT bits are set, the DMA FIFO 
is empty. 

Bits 3-0 FFL3-0 (Byte Full in DMA FIFO) 

These status bits identify the top bytes in the 
DMA FIFO that are full. Each bit corresponds 
to a byte lane in the DMA FIFO. For example, 
if byte lane three is full then FFL3 will be set. 
Since the FFL flags indicate the status of bytes 
at the top of the FIFO, if all FFL bits are set, 
the DMA FIFO is full. 
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Register 1A (9A) 

Chip Test Two (CTEST2) 
Read/Write 


DDIR 

SIGP 

CIO 

CM 

SRTCH 

TEOP 

DREQ 

DACK 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

0 0 

X 

X 

0 

0 

0 

1 


Bit 7 DDIR (Data Transfer Direction) 

This status bit indicates which direction data is 
being transferred. When this bit is set, the data 
will be transferred from the SCSI bus to the 
host bus. When this bit is clear, the data will be 
transferred from the host bus to the SCSI bus. 

Bit 6 SIGP (Signal Process) 

This bit is a copy of the SIGP bit in the ISTAT 
register (bit 5).The SIGP bit is used to signal a 
running SCRIPTS instruction. When this reg¬ 
ister is read, the SIGP bit in the ISTAT register 
is cleared. 

Bit 5 CIO (Configured as I/O) 

This bit is defined as the Configuration I/O 
Enable Status bit. This read-only bit indicates 
if the chip is currently enabled as I/O space. 

Note: both bits 4 and 5 may be set if the chip is 
dual-mapped. 

Bit 4 CM (Configured as Memory) 

This bit is defined as the configuration mem¬ 
ory enable status bit. This read-only bit indi¬ 
cates if the chip is currently enabled as 
memory space. 

Note: both bits 4 and 5 may be set if the chip is 
dual-mapped. 


Bit 3 SRTCH (SCRATCHA/B Operation) 

This bit controls the operation of the 
SCRATCHA and SCRATCHB registers. 
When it is set, SCRATCHB contains the RAM 
base address value from the PCI configuration 
RAM Base Address register. This is the base 
address for the 4 KB internal RAM. In addi¬ 
tion, the SCRATCHA register displays the 
memory-mapped based address of the chip 
operating registers. When this bit is clear, the 
SCRATCHA and SCRATCHB registers 
return to normal operation. 

Note: bit 3 is the only writable bit in this register. 
All other bits are read only. When 
modifying this register, all other bits must 
be written to zero. Do not execute a Read- 
Modify-Write to this register. 

Bit 2 TEOP (SCSI True End of Process) 

This bit indicates the status of the 
SYM53C895’s internal TEOP signal. The 
TEOP signal acknowledges the completion of 
a transfer through the SCSI portion of the 
SYM53C895.When this bit is set,TEOP is 
active. When this bit is clear,TEOP is inactive. 

Bit 1 DREQ (Data Request Status) 

This bit indicates the status of the 
SYM53C895’s internal Data Request signal 
(DREQ).When this bit is set, DREQ is active. 
When this bit is clear, DREQ is inactive. 

Bit 0 DACK (Data Acknowledge Status) 

This bit indicates the status of the 
SYM53C895’s internal Data Acknowledge sig¬ 
nal (DACK/).When this bit is set, DACK/ is 
inactive. When this bit is clear, DACK/ is 
active. 
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Register IB (9B) 

Chip Test Three (CTEST3) 
Read/Write 


V3 

V 2 

VI 

VO 

FLF 

CLF 

FM 

WRIE 

7 

6 

5 

4 

3 

2 

1 

0 

Defau lt»> 

X X 

X 

X 

0 

0 

0 

0 


Bits 7-4 V3-V0 (Chip revision level) 

These bits identify the chip revision level for 
software purposes. The value should be the 
same as the lower nibble of the PCI Revision 
ID Register, at address 08h in configuration 
space. 

Bit 3 FLF (Flush DMA FIFO) 

When this bit is set, data residing in the DMA 
FIFO is transferred to memory, starting at the 
address in the DNAD register. The internal 
DMAWR signal, controlled by the CTEST5 
register, determines the direction of the trans¬ 
fer. This bit is not self clearing; once the 
SYM53C895 has successfully transferred the 
data, this bit should be reset. 

Note: polling of FIFO flags is allowed during 
flush operations. 


Bit 1 FM (Fetch Pin Mode) 

When set, this bit causes the FETCH/ pin to 
deassert during indirect and table indirect read 
operations. FETCH/ will only be active during 
the op code portion of an instruction fetch. 
This allows SCRIPTS to be stored in a PROM 
while data tables are stored in RAM. 

If this bit is not set, FETCH/ will be asserted 
for all bus cycles during instruction fetches. 

Bit 0 WRIE (Write and Invalidate Enable) 

This bit, when set, causes Memory Write and 
Invalidate commands to be issued on the PCI 
bus after certain conditions have been met. 
These conditions are described in detail in 
Chapter 3. 


Bit 2 CLF (Clear DMA FIFO) 

When this bit is set, all data pointers for the 
DMA FIFO are cleared. Any data in the FIFO 
is lost. This bit automatically resets after the 
SYM53C895 has successfully cleared the 
appropriate FIFO pointers and registers. 

Note: this bit does not clear the data visible at the 
bottom of the FIFO. 
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Registers 1C-IF (9C-9F) 

Temporary (TEMP) 

Read/Write 

This 32-bit register stores the Return instruction 
address pointer from the Call instruction. The ad¬ 
dress pointer stored in this register is loaded into 
the DSP register when a Return instruction is exe¬ 
cuted. This address points to the next instruction to 
be executed. Do not write to this register while the 
SYM53C895 is executing SCRIPTS. 

During any Memory-to-Memory Move operation, 
the contents of this register are preserved. The 
power-up value of this register is indeterminate. 


Register 20 (AO) 
DMA FIFO (DFIFO) 
Read/Write 


B07 

B06 

B05 

B04 

Bo3 

B02 

B01 

BOO 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

X 0 

0 

0 

0 

0 

0 

0 


Bits 7-0 BO7-BO0 (Byte offset counter) 

These bits, along with bits 1-0 in the CTEST5 
register, indicate the amount of data trans¬ 
ferred between the SCSI core and the DMA 
core. It may be used to determine the number 
of bytes in the DMA FIFO when an interrupt 
occurs. These bits are unstable while data is 
being transferred between the two cores; once 
the chip has stopped transferring data, these 
bits are stable. 

Since the DFIFO register counts the number 
of bytes transferred between the DMA core 
and the SCSI core, and the DBC register 
counts the number of bytes transferred across 
the host bus, the difference between these two 
counters represents the number of bytes 
remaining in the DMA FIFO. 

The following steps will determine how many 
bytes are left in the DMA FIFO when an error 
occurs, regardless of the direction of the trans¬ 
fer: 

1. If the DMA FIFO size is set to 112 bytes, 
subtract the seven least significant bits of 
the DBC register from the 7-bit value of 
the DFIFO register. 

If the DMA FIFO size is set to 816 bytes 
(using bit 5 of the CTEST5 register), sub¬ 
tract the 10 least significant bits of the 
DBC register from the 10-bit value of the 
DMA FIFO Byte Offset Counter, which 
consists of bits 1-0 in the CTEST5 register 
and bits 7-0 of the DMA FIFO register. 
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2. If the DMA FIFO size is set to 112 bytes, 
AND the result with 7Fh for a byte count 
between zero and 64. If the DMA FIFO 
size is set to 816 bytes, AND the result with 
3FFh for a byte count between 0 and 816. 

Note: to calculate the total number of bytes in 
both the DMA FIFO and SCSI logic, see 
the section on Data Paths in Chapter Two, 
“Functional Description.” 


Register 21 (Al) 

Chip Test Four (CTEST4) 
Read/Write 


BDIS 

ZMOD 

ZSD 

SRTM 

MPEE 

FBL2 

FB LI 

FBLO 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7 BDIS (Burst Disable) 

When set, this bit will cause the SYM53C895 
to perform back to back cycles for all transfers. 
When reset, the SYM53C895 will perform 
back to back transfers for op code fetches and 
burst transfers for data moves. 

Bit 6 ZMOD (High Impedance Mode) 

Setting this bit causes the SYM53C895 to 
place all output and bidirectional pins into a 
high-impedance state. In order to read data out 
of the SYM53C895, this bit must be cleared. 
This bit is intended for board-level testing only. 
Do not set this bit during normal system oper¬ 
ation. 

Bit 5 ZSD (SCSI Data High Impedance) 

Setting this bit causes the SYM53C895 to 
place the SCSI data bus SD(15-0) and the par¬ 
ity lines SDP(l-O) in a high-impedance state. 
In order to transfer data on the SCSI bus, this 
bit must be cleared. 

Bit 4 SRTM (Shadow Register Test Mode) 

Setting this bit allows access to the shadow reg¬ 
isters used by memory-to-memory Move oper¬ 
ations. When this bit is set, register accesses to 
the TEMP and DSA registers are directed to 
the shadow copies STEMP (Shadow TEMP) 
and SDSA (Shadow DSA). The registers are 
shadowed to prevent them from being over¬ 
written during a Memory-to-Memory Move 
operation. The DSA and TEMP registers con¬ 
tain the base address used for table indirect 
calculations, and the address pointer for a call 
or return instruction, respectively. This bit is 
intended for manufacturing diagnostics only 
and should not be set during normal opera¬ 
tions. 
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Bit 3 MPEE (Master Parity Error Enable) 

Setting this bit enables parity checking during 
master data phases. A parity error during a bus 
master read is detected by the SYM53C895. A 
parity error during a bus master write is 
detected by the target, and the SYM53C895 is 
informed of the error by the PERR/ pin being 
asserted by the target. When this bit is reset, 
the SYM53C895 will not interrupt if a master 
parity error occurs. This bit is reset at power 
up. 


Bits 2-0 FBL2-FBL0 (FIFO Byte Control) 


FBL2 

FBL1 

FBLO 

DMA FIFO 
Byte lane 

Pins 

0 

X 

X 

Disabled 

n/a 

1 

0 

0 

0 

D(7-0) 

1 

0 

1 

1 

D(15-8) 

1 

1 

0 

2 

D(23-16) 

1 

1 

1 

3 

D (31-24) 


These bits steer the contents of the CTEST6 
register to the appropriate byte lane of the 32- 
bit DMA FIFO. If the FBL2 bit is set, then 
FBL1 and FBLO determine which of four byte 
lanes can be read or written. When cleared, the 
byte lane read or written is determined by the 
current contents of the DNAD and DBC regis¬ 
ters. Each of the four bytes that make up the 
32-bit DMA FIFO can be accessed by writing 
these bits to the proper value. For normal 
operation, FBL2 must equal zero. 


Register 22 (A2) 

Chip Test Five (CTEST5) 
Read/Write 


ADCK 

BBCK 

DFS 

MASR 

DDIR 

BL2 

B09 

B08 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

0 0 

0 

0 

0 

X 

X 

X 


Bit 7 ADCK (Clock Address Incrementor) 

Setting this bit increments the address pointer 
contained in the DNAD register. The DNAD 
register is incremented based on the DNAD 
contents and the current DBC value.This bit 
automatically clears itself after incrementing 
the DNAD register. 

Bit 6 BBCK (Clock Byte Counter) 

Setting this bit decrements the byte count con¬ 
tained in the 24-bit DBC register. It is decre¬ 
mented based on the DBC contents and the 
current DNAD value. This bit automatically 
clears itself after decrementing the DBC regis¬ 
ter. 

Bit 5 DFS (DMA FIFO Size) 

This bit controls the size of the DMA FIFO. 
When clear, the DMA FIFO will be 112 bytes 
deep. When set, the DMA FIFO size will 
increase to 816 bytes. Using a 112-byte FIFO 
allows software written for other 
SYM53C8XX family chips to properly calcu¬ 
late the number of bytes residing in the chip 
after a target disconnect. The default value of 
this bit is zero. 

Bit 4 MASK (Master Control for Set or 
Reset Pulses) 

This bit controls the operation of bit 3. When 
this bit is set, bit 3 asserts the corresponding 
signals. When this bit is reset, bit 3 deasserts 
the corresponding signals. This bit and bit 3 
should not be changed in the same write cycle. 
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Bit 3 DDIR (DMA Direction) 

Setting this bit either asserts or deasserts the 
internal DMA Write (DMAWR) direction sig¬ 
nal depending on the current status of the 
MASR bit in this register. Asserting the 
DMAWR signal indicates that data will be 
transferred from the SCSI bus to the host bus. 
Deasserting the DMAWR signal transfers data 
from the host bus to the SCSI bus. 

Bit 2 BL2 (Burst Length bit 2) 

This bit works with bits 6 and 7 in the 
DMODE register to determine the burst 
length. For complete definitions of this field, 
refer to the descriptions of DMODE bits 6 and 
7. This bit is disabled if an 112-byte FIFO is 
selected by clearing the DMA FIFO Size bit. 

Bits 1-0 B09-8 

These are the upper two bits of the DMA 
FIFO byte offset counter. The entire field is 
described under the DFIFO register, bits 7-0. 


Register 23 (A3) 

Chip Test Six (CTEST6) 
Read/Write 


DF7 

DF6 

DF5 

DF4 

DF3 

DF2 

DF1 

DFO 

7 

6 

5 

4 

3 

2 

1 

0 

Default>» 

0 0 

0 

0 

0 

0 

0 

0 


Bits 7-0 DF7-DF0 (DMA FIFO) 

Writing to this register writes data to the 
appropriate byte lane of the DMA FIFO as 
determined by the FBL bits in the CTEST4 
register. Reading this register unloads data 
from the appropriate byte lane of the DMA 
FIFO as determined by the FBL bits in the 
CTEST4 register. Data written to the FIFO is 
loaded into the top of the FIFO. Data read out 
of the FIFO is taken from the bottom. To pre¬ 
vent DMA data from being corrupted, this reg¬ 
ister should not be accessed during normal 
operation. This register should only be written 
when testing the DMA FIFO using the 
CTEST4 register. Reads or writes to this regis¬ 
ter while the test mode is not enabled will have 
unexpected results. 
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Registers 24-26 (A4-A6) 

DMA Byte Counter (DBC) 

Read/Write 

This 24-bit register determines the number of bytes 
to be transferred in a Block Move instruction. 
While sending data to the SCSI bus, the counter is 
decremented as data is moved into the DMA FIFO 
from memory. While receiving data from the SCSI 
bus, the counter is decremented as data is written 
to memory from the SYM53C895. The DBC 
counter is decremented each time that data is trans¬ 
ferred on the PCI bus. It is decremented by an 
amount equal to the number of bytes that were 
transferred. 

The maximum number of bytes that can be trans¬ 
ferred in any one Block Move command is 
16,777,215 bytes. The maximum value that can be 
loaded into the DBC register is FFFFFFh. If the 
instruction is a Block Move and a value of OOOOOOh 
is loaded into the DBC register, an illegal instruc¬ 
tion interrupt will occur if the SYM53C895 is not 
in target mode, Command phase. 

The DBC register is also used to hold the least sig¬ 
nificant 24 bits of the first dword of a SCRIPT 
fetch, and to hold the offset value during table indi¬ 
rect I/O SCRIPTS. For a complete description, see 
Chapter Six, “Instruction Set of the I/O Proces¬ 
sor.” The power-up value of this register is indeter¬ 
minate. 


Register 27 (A7) 

DMA Command (DCMD) 

Read/Write 

This 8-bit register determines the instruction for 
the SYM53C895 to execute. This register has a dif¬ 
ferent format for each instruction. For complete de¬ 
scriptions, see Chapter Six, “Instruction Set of the 
I/O Processor.” 
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Registers 28-2B (A8-AB) 

DMA Next Address (DNAD) 

Read/Write 

This 32-bit register contains the general purpose 
address pointer. At the start of some SCRIPTS op¬ 
erations, its value is copied from the DSPS register. 
Its value may not be valid except in certain abort 
conditions. The default value of this register is zero. 

This register should not be used to determine data 
addresses during a Phase Mismatch interrupt, as its 
value is not always correct for this use. The DBC, 
DFIFO, and DSPS registers should be used to cal¬ 
culate residual byte counts and addresses as de¬ 
scribed in the Data Paths section in Chapter 2. 


Registers 2C-2F (AC-AF) 

DMA SCRIPTS Pointer (DSP) 
Read/Write 

To execute SCSI SCRIPTS, the address of the first 
SCRIPTS instruction must be written to this regis¬ 
ter. In normal SCRIPTS operation, once the start¬ 
ing address of the SCRIPT is written to this 
register, SCRIPTS are automatically fetched and 
executed until an interrupt condition occurs. 

In single-step mode, there is a single step interrupt 
after each instruction is executed. The DSP register 
does not need to be written with the next address, 
but the Start DMA bit (bit 2, DCNTL register) 
must be set each time the step interrupt occurs to 
fetch and execute the next SCRIPTS command. 
When writing this register eight bits at a time, writ¬ 
ing the upper eight bits begins execution of 
SCSI SCRIPTS. The default value of this register 
is zero. 
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Registers 30-33 (B0-B3) 

DMA SCRIPTS Pointer Save (DSPS) 
Read/Write 

This register contains the second dword of a 
SCRIPTS instruction. It is overwritten each time a 
SCRIPTS instruction is fetched. When a 
SCRIPTS interrupt instruction is executed, this 
register holds the interrupt vector. The power-up 
value of this register is indeterminate. 


Registers 34-37 (B4-B7) 

Scratch Register A (SCRATCH A) 
Read/Write 

This is a general purpose, user-definable scratch 
pad register. Apart from CPU access, only Register 
Read/Write and Memory Moves into the 
SCRATCH register will alter its contents. The 
SYM53C895 cannot fetch SCRIPTS instructions 
from this location. When bit 3 in the CTEST2 reg¬ 
ister is set, this register contains the memory- 
mapped base address of the operating registers. 
Setting CTEST2 bit 3 only causes the base address 
to appear in this register; any information that was 
previously in the register will remain intact. Any 
writes to this register while CTEST2 bit 3 is set will 
pass through to the actual SCRATCHA register. 
The power-up value of this register is indetermi¬ 
nate. 
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Register 38 (B8) 

DMA Mode (DMODE) 
Read/Write 


BL1 

BL0 

SIOM 

DIOM 

ER 

ERMP 

BOF 

MAN 

7 

6 

5 

4 

3 

2 

1 

0 


Default>» 

0 0 0 0 0 0 0 0 


Bit 7-6 BL1-BLO (Burst Length) 

These bits control the maximum number of 
transfers performed per bus ownership, regard¬ 
less of whether the transfers are back-to-back, 
burst, or a combination of both. The 
SYM53C895 asserts the Bus Request (REQ/) 
output when the DMA FIFO can accommo¬ 
date a transfer of at least one burst size of data. 
Bus Request (REQ/) is also asserted during 
start-of-transfer and end-of-transfer cleanup 
and alignment, even though less than a full 
burst of transfers may be performed. The 
SYM53C895 inserts a “fairness delay” of four 
CLKs between burst-length transfers (as set in 
BL1-0) during normal operation. The fairness 
delay is not inserted during PCI retry cycles. 
This gives the CPU and other bus master 
devices the opportunity to access the PCI bus 
between bursts. 


Table 5-8: Burst Length Bit Decoding 


BL2 

(CTEST5 
bit 2) 

BL1 

BL0 

Burst Length 

0 

0 

0 

2- transfer burst 

0 

0 

1 

4- transfer burst 

0 

1 

0 

8-transfer burst 

0 

1 

1 

16-transfer burst 

1 

0 

0 

32-transfer burst* 

1 

0 

1 

64-transfer burst* 

1 

1 

0 

128-transfer burst* 

1 

1 

1 

Reserved 


* Only valid, if the FIFO size is set to 816 bytes 


Bit 5 SIOM (Source I/O-Memory Enable) 

This bit is defined as an I/O Memory Enable 
bit for the source address of a Memory Move 
or Block Move Command. If this bit is set, 
then the source address is in I/O space; and if 
reset, then the source address is in memory 
space. 

This function is useful for register-to-memory 
operations using the Memory Move instruc¬ 
tion when the SYM53C895 is I/O mapped. 

Bits 4 and 5 of the CTEST2 register can be 
used to determine the configuration status of 
the SYM53C895. 

Bit 4 DIOM (Destination I/O-Memory 
Enable) 

This bit is defined as an I/O Memory Enable 
bit for the destination address of a Memory 
Move or Block Move Command. If this bit is 
set, then the destination address is in I/O 
space; and if reset, then the destination address 
is in memory space. 

This function is useful for memory-to-register 
operations using the Memory Move instruc¬ 
tion when the SYM53C895 is I/O mapped. 
Bits 4 and 5 of the CTEST2 register can be 
used to determine the configuration status of 
the SYM53C895. 

Bit 3 ERL (Enable Read Line) 

This bit enables a PCI Read Line command. If 
PCI cache mode is enabled by setting bits in 
the PCI Cache Line Size register, this chip 
issues a Read Line command on all read cycles 
if other conditions are met. For more informa¬ 
tion on these conditions, refer to Chapter 3. 

Bit 2 ERMP (Enable Read Multiple) 

This bit, when set, will cause Read Multiple 
commands to be issued on the PCI bus after 
certain conditions have been met. These condi¬ 
tions are described in Chapter 3. 
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Bit 1 BOF (Burst Op Code Fetch Enable) 

Setting this bit causes the SYM53C895 to 
fetch instructions in burst mode. Specifically, 
the chip will burst in the first two dwords of all 
instructions using a single bus ownership. If 
the instruction is a memory-to-memory move 
type, the third dword will be accessed in a sub¬ 
sequent bus ownership. If the instruction is an 
indirect type, the additional dword will be 
accessed in a subsequent bus ownership. If the 
instruction is a table indirect block move type, 
the chip will access the remaining two dwords 
in a subsequent bus ownership, thereby fetch¬ 
ing the four dwords required in two bursts of 
two dwords each. This bit has no effect if 
SCRIPTS instruction prefetching is enabled. 

Bit 0 MAN (Manual Start Mode) 

Setting this bit prevents the SYM53C895 from 
automatically fetching and executing SCSI 
SCRIPTS when the DSP register is written. 
When this bit is set, the Start DMA bit in the 
DCNTL register must be set to begin 
SCRIPTS execution. Clearing this bit causes 
the SYM53C895 to automatically begin fetch¬ 
ing and executing SCSI SCRIPTS when the 
DSP register is written.This bit normally is not 
used for SCSI SCRIPTS operations. 


Register 39 (B9) 

DMA Interrupt Enable (DIEN) 
Read/Write 


RES 

MDPE 

BF 

ABRT 

SSI 

SIR 

RES 

IID 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

X 0 

0 

0 

0 

0 

X 

0 


This register contains the interrupt mask bits corre¬ 
sponding to the interrupting conditions described 
in the DSTAT register. An interrupt is masked by 
clearing the appropriate mask bit. Masking an in¬ 
terrupt prevents IRQ/ from being asserted for the 
corresponding interrupt, but the status bit will still 
be set in the DSTAT register. Masking an interrupt 
will not prevent the ISTAT DIP from being set. All 
DMA interrupts are considered fatal, therefore 
SCRIPTS will stop running when this condition 
occurs, whether or not the interrupt is masked. Set¬ 
ting a mask bit enables the assertion of IRQ/ for the 
corresponding interrupt. (A masked non-fatal in¬ 
terrupt will not prevent un-masked or fatal inter¬ 
rupts from getting through; interrupt stacking 
begins when either the ISTAT SIP or DIP bit is 
set.) 

The SYM53C895 IRQ/ output is latched; once as¬ 
serted, it will remain asserted until the interrupt is 
cleared by reading the appropriate status register. 
Masking an interrupt after the IRQ/ output is as¬ 
serted will not cause IRQ/ to be deasserted. 

For more information on interrupts, see Chapter 


Two, 

“Functional Description.” 

Bit 7 

Reserved 

Bit 6 

MDPE (Master Data Parity Error) 

Bit 5 

BF (Bus Fault) 

Bit 4 

ABRT (Aborted) 

Bit 3 

SSI (Single -step Interrupt) 

Bit 2 

SIR (SCRIPTS Interrupt 

Instruction Received 

Bit 1 

Reserved 

BitO 

IID (Illegal Instruction Detected) 
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Register 3A (BA) 

Scratch Byte Register (SBR) 

Read/Write 

This is a general purpose register. Apart from CPU 
access, only Register Read/Write and Memory 
Moves into this register will alter its contents. The 
default value of this register is zero. This register 
was called the DMA Watchdog Timer on previous 
SYM53C8XX family products. 


Register 3B (BB) 

DMA Control (DCNTL) 
Read/Write 


CLSE 

PFF 

PFEN 

SSM 

IRQM 

STD 

IRQD 

COM 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7 CLSE (Cache Line Size Enable) 

Setting this bit enables the SYM53C895 to 
sense and react to cache line boundaries set up 
by the DMODE or PCI Cache Line Size regis¬ 
ter, whichever contains the smaller value. 
Clearing this bit disables the cache line size 
logic and the SYM53C895 monitors the cache 
line size via the DMODE register. 


Bit 6 PFF (Pre-fetch Flush) 

Setting this bit will cause the pre-fetch unit to 
flush its contents. The bit will reset after the 
flush is complete. 


Bit 5 PFEN (Pre-fetch Enable) 

Setting this bit enables the pre-fetch unit if the 
burst size is equal to or greater than four. For 
more information on SCRIPTS instruction 
prefetching, see Chapter 2. 

Bit 4 SSM (Single-step Mode) 

Setting this bit causes the SYM53C895 to stop 
after executing each SCRIPTS instruction, 
and generate a single step interrupt. When this 
bit is clear the SYM53C895 will not stop after 
each instruction; instead it continues fetching 
and executing instructions until an interrupt 
condition occurs. For normal SCSI SCRIPTS 
operation, this bit should be clear. To restart 
the SYM53C895 after it generates a SCRIPTS 
Step interrupt, the ISTAT and DSTAT regis¬ 
ters should be read to recognize and clear the 
interrupt and then the START DMA bit in this 
register should be set. 
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Bit 3 IRQM (IRQ Mode) 

When set, this bit will enable a totem pole 
driver for the IRQ pin. When reset, this bit will 
enable an open drain driver for the IRQ pin 
with a internal weak pull-up. This bit is reset at 
power up. The bit should remain clear to retain 
full PCI compliance. 

Bit 2 STD (Start DMA Operation) 

The SYM53C895 fetches a SCSI SCRIPTS 
instruction from the address contained in the 
DSP register when this bit is set. This bit is 
required if the SYM53C895 is in one of the 
following modes: 

1. Manual start mode - Bit 0 in the DMODE 
register is set 

2. Single-step mode - Bit 4 in the DCNTL 
register is set 

When the SYM53C895 is executing SCRIPTS 
in manual start mode, the Start DMA bit 
needs to be set to start instruction fetches, but 
does not need to be set again until an interrupt 
occurs. When the SYM53C895 is in single- 
step mode, the Start DMA bit needs to be set 
to restart execution of SCRIPTS after a single- 
step interrupt. 

Bit 1 IRQD (IRQ Disable) 

Setting this bit disables the IRQ pin; clearing 
the bit enables normal operation. As with any 
other register other than ISTAT, this register 
can not be accessed except by a SCRIPTS 
instruction during SCRIPTS execution. For 
more information on the use of this bit in inter¬ 
rupt handling, see Chapter 2. 

Bit 0 COM (53C700 Compatibility) 

When this bit is clear, the SYM53C895 will 
behave in a manner compatible with the 
SYM53C700; selection/reselection IDs will be 
stored in both the SSID and SFBR registers. 

When this bit is set, the ID will be stored only 
in the SSID register, protecting the SFBR from 
being overwritten if a selection/reselection 
occurs during a DMA register-to-register oper¬ 
ation. This bit is not affected by a software 
reset. 


Register 3C-3F (BC-BF) 

Adder Sum Output (ADDER) 

Read Only 

This register contains the output of the internal 
adder, and is used primarily for test purposes. The 
power-up value for this register is indeterminate. 
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Register 40 (CO) 

SCSI Interrupt Enable Zero (SIENO) 
Read/Write 


M/A 

CMP 

SEL 

RSL 

SGE 

UDC 

RST 

PAR 

7 

6 

5 

A 

3 

2 

1 

0 

Default»> 

0 0 

0 

0 

0 

0 

0 

0 


This register contains the interrupt mask bits corre¬ 
sponding to the interrupting conditions described 
in the SISTO register. An interrupt is masked by 
clearing the appropriate mask bit. For more infor¬ 
mation on interrupts, see Chapter 2. 

Bit 7 M/A (SCSI Phase Mismatch - 
Initiator Mode; SCSI ATN 
Condition - Target Mode) 

Setting this bit allows the SYM53C895 to gen¬ 
erate an interrupt when a Phase Mismatch or 
ATN condition occurs. 

Bit 6 CMP (Function Complete) 

Setting this bit allows the SYM53C895 to gen¬ 
erate an interrupt when a full arbitration and 
selection sequence has completed. 

Bit 5 SEL (Selected) 

Setting this bit allows the SYM53C895 to gen¬ 
erate an interrupt when the SYM53C895 has 
been selected by a SCSI target device. 

Bit 4 RSL (Reselected) 

Setting this bit allows the SYM53C895 to gen¬ 
erate an interrupt when the SYM53C895 has 
been reselected by a SCSI initiator device. 

Bit 3 SGE (SCSI Gross Error) 

Setting this bit allows the SYM53C895 to gen¬ 
erate an interrupt when a SCSI gross error 
occurs.The following conditions are consid¬ 
ered SCSI Gross Errors: 

1. Data underflow - the SCSI FIFO was read 
when no data was present. 

2. Data overflow - the SCSI FIFO was 
written to while full. 


3. Offset underflow - in target mode, a 
SACK/ pulse was received before the 
corresponding SREQ/ was sent. 

4. Offset overflow - in initiator mode, an 
SREQ/ pulse was received which caused 
the maximum offset (Defined by the M03- 
0 bits in the SXFER register) to be 
exceeded. 

5. In initiator mode, a phase change occurred 
with an outstanding SREQ/SACK offset. 

6. Residual data in SCSI FIFO - a transfer 
other than synchronous data receive was 
started with data left in the SCSI 
synchronous receive FIFO. 

Bit 2 UDC (Unexpected Disconnect) 

Setting this bit allows the SYM53C895 to gen¬ 
erate an interrupt when an unexpected discon¬ 
nect occurs.This condition only occurs in 
initiator mode. It happens when the target to 
which the SYM53C895 is connected discon¬ 
nects from the SCSI bus unexpectedly. See the 
SCSI Disconnect Unexpected bit in the 
SCNTL2 register for more information on 
expected versus unexpected disconnects. Any 
disconnect in low level mode causes this condi¬ 
tion. 

Bit 1 RST (SCSI Reset Condition) 

Setting this bit allows the SYM53C895 to gen¬ 
erate an interrupt when the SRST/ signal has 
been asserted by the SYM53C895 or any other 
SCSI device. This condition is edge-triggered, 
so multiple interrupts cannot occur because of 
a single SRST/ pulse. 

Bit 0 PAR (SCSI Parity Error) 

Setting this bit allows the SYM53C895 to gen¬ 
erate an interrupt when the SYM53C895 
detects a parity error while receiving or sending 
SCSI data. See the Disable Halt on Parity 
Error or SATN/ Condition bits in the 
SCNTL1 register for more information on 
when this condition will actually be raised. 
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Register 41 (Cl) 

SCSI Interrupt Enable One (SIEN1) 
Read/Write 


RES 

RES 

RES 

SBMC 

RES 

STO 

GEN 

HTH 

7 

6 

5 

4 

3 

2 

1 

0 

Defauit»> 

X X 

X 

0 

X 

0 

0 

0 


This register contains the interrupt mask bits corre¬ 
sponding to the interrupting conditions described 
in the SISTl register. An interrupt is masked by 
clearing the appropriate mask bit. For more infor¬ 
mation on interrupts, refer to Chapter 2, “Func¬ 
tional Description.” 

Bits 7-5 Reserved 

Bit 4 SBMC (SCSI Bus Mode Change) 

Setting this bit allows the SYM53C895 to gen¬ 
erate an interrupt when the DIFFSENS pin 
detects a change in voltage level that indicates 
the SCSI bus has changed between single- 
ended, LVD, or high-power differential modes. 
For example, when this bit is clear and the 
SCSI bus changes modes, IRQ/ does not assert 
and the SIP bit in the ISTAT register is not set. 
However, bit 4 is the SISTl register is set. Set¬ 
ting this bit allows the interrupt to occur. 


Bit 1 GEN (General Purpose Timer 

Expired) 

Setting this bit allows the SYM53C895 to gen¬ 
erate an interrupt when the general purpose 
timer has expired. The time measured is the 
time between enabling and disabling of the 
timer. See the description of the STIMEl reg¬ 
ister, bits 3-0, for more information on the 
general purpose timer. 

Bit 0 HTH ( Handshake-to-Handshake 

Timer Expired) 

Setting this bit allows the SYM53C895 to gen¬ 
erate an interrupt when the handshake-to- 
handshake timer has expired. The time mea¬ 
sured is the SCSI Request-to-Request (target) 
or Acknowledge-to-Acknowledge (initiator) 
period. See the description of the STIMEO 
register, bits 7-4, for more information on the 
handshake-to-handshake timer. 


Bit 3 Reserved 

Bit 2 STO (Selection or Reselection Time¬ 

out) 

Setting this bit allows the SYM53C895 to gen¬ 
erate an interrupt when a selection or reselec¬ 
tion timeout occurs.See the description of the 
STIMEO register bits 3-0 for more information 
on the time-out periods. 
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Register 42 (C2) 

SCSI Interrupt Status Zero (SISTO) 
Read Only 


M/A 

CMP 

SEL 

RSL 

SGE 

UDC 

RST 

PAR 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

0 0 

0 

0 

0 

0 

0 

0 


Reading the SISTO register returns the status of the 
various interrupt conditions, whether they are en¬ 
abled in the SIENO register or not. Each bit set in¬ 
dicates that the corresponding condition has 
occurred. Reading the SISTO will clear the inter¬ 
rupt status. 

Reading this register will clear any bits that are set 
at the time the register is read, but will not neces¬ 
sarily clear the register because additional inter¬ 
rupts may be pending (the SYM53C895 stacks 
interrupts). SCSI interrupt conditions may be indi¬ 
vidually masked through the SIENO register. 

When performing consecutive 8-bit reads of the 
DSTAT, SISTO, and SISTl registers (in any or¬ 
der), insert a delay equivalent to 12 CLK periods 
between the reads to ensure the interrupts clear 
properly. Also, if reading the registers when both 
the ISTAT SIP and DIP bits may not be set, the 
SISTO and SIST1 registers should be read before 
the DSTAT register to avoid missing a SCSI inter¬ 
rupt. For more information on interrupts, refer to 
Chapter 2, “Functional Description.” 

Bit 7 M/A (Initiator Mode: Phase Mis¬ 
match; Target Mode: SATN/ Active) 

In initiator mode, this bit is set if the SCSI 
phase asserted by the target does not match the 
instruction. The phase is sampled when SREQ/ 
is asserted by the target. In target mode, this 
bit is set when the SATN/ signal is asserted by 
the initiator. 

Bit 6 CMP (Function Complete) 

This bit is set when an arbitration only or full 
arbitration sequence has completed. 


Bit 5 SEL (Selected) 

This bit is set when the SYM53C895 is 
selected by another SCSI device. The Enable 
Response to Selection bit must have been set in 
the SCID register (and the RESPID register 
must hold the chip’s ID) for the SYM53C895 
to respond to selection attempts. 

Bit 4 RSL (Reselected) 

This bit is set when the SYM53C895 is rese¬ 
lected by another SCSI device. The Enable 
Response to Reselection bit must have been set 
in the SCID register (and the RESPID register 
must hold the chip’s ID) for the SYM53C895 
to respond to reselection attempts. 

Bit 3 SGE (SCSI Gross Error) 

This bit is set when the SYM53C895 encoun¬ 
ters a SCSI Gross Error Condition. The fol¬ 
lowing conditions can result in a SCSI Gross 
Error Condition: 

1. Data Underflow - the SCSI FIFO register 
was read when no data was present. 

2. Data Overflow - too many bytes were 
written to the SCSI FIFO or the 
synchronous offset caused the SCSI FIFO 
to be overwritten. 

3. Offset Underflow - the SYM53C895 is 
operating in target mode and a SACK/ 
pulse is received when the outstanding 
offset is zero. 

4. Offset Overflow - the other SCSI device 
sent a SREQ/ or SACK/ pulse with data 
which exceeded the maximum 
synchronous offset defined by the SXFER 
register. 

5. A phase change occurred with an 
outstanding synchronous offset when the 
SYM53C895 was operating as an initiator. 

6. Residual data in the Synchronous data 
FIFO - a transfer other than synchronous 
data receive was started with data left in the 
synchronous data FIFO. 
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Bit 2 UDC (Unexpected Disconnect) 

This bit is set when the SYM53C895 is operat¬ 
ing in initiator mode and the target device 
unexpectedly disconnects from the SCSI bus. 
This bit is only valid when the SYM53C895 
operates in the initiator mode. When the 
SYM53C895 operates in low level mode, any 
disconnect will cause an interrupt, even a valid 
SCSI disconnect. This bit will also be set if a 
selection time-out occurs (it may occur before, 
at the same time, or stacked after the STO 
interrupt, since this is not considered an 
expected disconnect). 

Bit 1 RST (SCSI RST/ Received) 

This bit is set when the SYM53C895 detects 
an active SRST/ signal, whether the reset was 
generated external to the chip or caused by the 
Assert SRST/ bit in the SCNTL1 register.This 
SYM53C895 SCSI reset detection logic is 
edge-sensitive, so that multiple interrupts will 
not be generated for a single assertion of the 
SRST/ signal. 

Bit 0 PAR (Parity Error) 

This bit is set when the SYM53C895 detects a 
parity error while receiving SCSI data. The 
Enable Parity Checking bit (bit 3 in the 
SCNTLO register) must be set for this bit to 
become active.The SYM53C895 always gen¬ 
erates parity when sending SCSI data. 


Register 43 (C3) 

SCSI Interrupt Status One (SISTI) 
Read Only 


RES 

RES 

RES 

SBMC 

RES 

STO 

GEN 

HTH 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

X X 

X 

0 

X 

0 

0 

0 


Reading the SISTI register returns the status of the 
various interrupt conditions, whether they are en¬ 
abled in the SIEN1 register or not. Each bit that is 
set indicates the corresponding condition has oc¬ 
curred. 

Reading the SISTI and SISTO registers will clear 
the interrupt condition. 

Bits 7-5 Reserved 

Bit 4 SBMC (SCSI Bus Mode Change) 

This bit is set when the DIFFSENS pin detects 
a change in voltage level that indicates the 
SCSI bus has switched between single-ended, 
LVD, or high-power differential modes. 

Bit 3 Reserved 

Bit 2 STO (Selection or Reselection 

Time-out) 

The SCSI device which the SYM53C895 was 
attempting to select or reselect did not respond 
within the programmed time-out period. See 
the description of the STIMEO register, bits 3- 
0, for more information on the time-out timer. 

Bit 1 GEN (General Purpose Timer 

Expired) 

This bit is set when the general purpose timer 
has expired. The time measured is the time 
between enabling and disabling of the timer. 
See the description of the STIMEl register, 
bits 3-0, for more information on the general 
purpose timer. 
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Bit 0 HTH (Handshake-to-Handshake 
Timer Expired) 

This bit is set when the handshake-to-hand- 
shake timer has expired. The time measured is 
the SCSI Request to Request (target) or 
Acknowledge to Acknowledge (initiator) 
period. See the description of the STIMEO 
register, bits 7-4, for more information on the 
handshake-to-handshake timer. 


Register 44 (C4) 

SCSI Longitudinal Parity (SLPAR) 
Read/Write 

The SLPAR register consists of two multiplexed 
bytes; other register bit settings determine what is 
displayed at this memory location at any given time. 
When bit 5 in the SCNTL2 (SLPMD) register is 
cleared, the chip XORs the high and low bytes of 
the SLPAR register together to give a single-byte 
value which is displayed in the SLPAR register. If 
the SLPMD bit is set, then the SLPAR register 
shows either the high byte or the low byte of the 
SLPAR word. The SLPAR High Byte Enable bit, 
SCNTL2 bit 4, determines which byte of the 
SLPAR register is visible on the SLPAR register at 
any given time. If this bit is cleared, the SLPAR reg¬ 
ister contains the low byte of the SLPAR word; if it 
is set, the SLPAR register contains the high byte of 
the SLPAR word. 

This register performs a bytewise longitudinal par¬ 
ity check on all SCSI data received or sent through 
the SCSI core. If one of the bytes received or sent 
(usually the last) is the set of correct even parity 
bits, SLPAR should go to zero (assuming it started 
at zero). As an example, suppose that the following 
three data bytes and one check byte are received 
from the SCSI bus (all signals are shown active 
high): 


Data Bytes 

Running SLPAR 

— 

00000000 

1.11001100 

11001100 (XOR of word 1) 

2.01010101 

10011001 (XOR of word 1 and 2) 

3.00001111 

10010110 (XOR of word 1,2 and 3) 
Even Parity >>>10010110 

4.10010110 

00000000 


A one in any bit position of the final SLPAR value 
would indicate a transmission error. 
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The SLPAR register can also be used to generate 
the check bytes for SCSI send operations. If the 
SLPAR register contains all zeros prior to sending 
a block move, it will contain the appropriate check 
byte at the end of the block move. This byte must 
then be sent across the SCSI bus. 

Note: writing any value to this register resets it to 
zero. 

The longitudinal parity checks are meant to provide 
an added measure of SCSI data integrity and are 
entirely optional. This register does not latch SCSI 
selection/reselection IDs under any circumstances. 
The default value of this register is zero. 


Register 45 (C5) 

SCSI Wide Residue (SWIDE) 

Read/Write 

After a wide SCSI data receive operation, this reg¬ 
ister will contain a residual data byte if the last byte 
received was never sent across the DMA bus. It 
represents either the first data byte of a subsequent 
data transfer, or it is a residue byte which should be 
cleared when an Ignore Wide Residue message is 
received. It may also be an overrun data byte. The 
power-up value of this register is indeterminate. 
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Register 46 (C6) 

Memory Access Control (MACNTL) 
Read/Write 


TYP3 

TYP2 

TYP1 

TYPO 

DWR 

DRD 

PSCPT 

SCPTS 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

1 1 

0 

1 

0 

0 

0 

0 


Bits 7-4 TYP3-0 (Chip Type) 

These bits identify the chip type for software 
purposes.This data manual applies to devices 
that have these bits set to ODh. 

Bits 3 through 0 of this register are used to deter¬ 
mine if an external bus master access is to local or 
far memory. When bits 3 through 0 are set, the cor¬ 
responding access is considered local and the 
MAC/_TESTOUT pin is driven high. When these 
bits are clear, the corresponding access is to far 
memory and the MAC/_TESTOUT pin is driven 
low. This function is enabled after a Transfer Con¬ 
trol SCRIPTS instruction is executed. 

Bit 3 DWR (DataWR) 

This bit is used to define if a data write is con¬ 
sidered local memory access. 


Register 47 (C7) 

General Purpose Pin Control (GPCNTL) 
Read/Write 


ME 

FE 


GPI04 

GPI03 

GPI02 

GPI01 

GPIOO 

7 

6 

5 

4 

3 

2 

1 

0 

Defau1t»> 

0 0 

X 

0 

1 

1 

1 

1 


This register is used to determine if the pins con¬ 
trolled by the General Purpose register (GPREG) 
are inputs or outputs. Bits 4-0 in GPCNTL corre¬ 
spond to bits 4-0 in the GPREG register. When the 
bits are enabled as inputs, an internal pull-up is also 
enabled. 

Bit 7 Master Enable 

The internal bus master signal will be pre¬ 
sented on GPIO1 if this bit is set, regardless of 
the state of Bit 1 (GPI01_EN). 

Bit 6 Fetch Enable 

The internal op code fetch signal will be pre¬ 
sented on GPIOO if this bit is set, regardless of 
the state of Bit 0 (GPIOO_EN). 

Bit 5 Reserved 


Bit 2 DRD (DataRD) 

This bit is used to define if a data read is con¬ 
sidered local memory access. 

Bit 1 PSCPT (Pointer SCRIPTS) 

This bit is used to define if a pointer to a 
SCRIPTS indirect or table indirect fetch is 
considered local memory access. 

Bit 0 SCPTS (SCRIPTS) 

This bit is used to define if a SCRIPTS fetch is 
considered local memory access. 


Bits 4-2 GPI04_EN-GPI02_EN (GPIO 
Enable) 

General purpose control, corresponding to bits 
4-2 in the GPREG register and pins 60, 59, 
and 57. GPI04 powers up as a general purpose 
output, and GPI03-2 power up as general pur¬ 
pose inputs. 

Bits 1-0 GPI01_EN- GPIOO_EN (GPIO 
Enable) 

These bits power up set, causing the GPIOl 
and GPIOO pins to become inputs. Resetting 
these bits causes GPIO 1-0 to become outputs. 


SYM53C895 Data Manual 


5-45 




Operating Registers 


Register 48 (C8) 

SCSI Timer Zero (STIMEO) 
Read /Write 


HTH 

HTH 

HTH 

HRH 

SEL 

SEL 

SEL 

SEL 

7 

6 

5 

4 

3 

2 

1 

0 

Defau lt»> 

0 0 

0 

0 

0 

0 

0 

0 


Bits 7-4 HTH (Ilandshake-to-IIandshake 
Timer Period) 

These bits select the handshake-to-handshake 
time-out period, the maximum time between 
SCSI handshakes (SREQ/ to SREQ/ in target 
mode, or SACK/ to SACK/ in initiator mode). 
When this timing is exceeded, an interrupt is 
generated and the HTH bit in the SISTl regis¬ 
ter is set.The following table contains time-out 
periods for the Handshake-to-Handshake 
Timer, the Selection/Reselection Timer (bits 3- 
0), and the General Purpose Timer (STIME1 
bits 3-0). For a more detailed explanation of 
interrupts, refer to Chapter 2, “Functional 
Description.” 


Table 5-9: Handshake-to Handshake Timer 
Period 


HTH 7-4, SEL 3-0, GEN 3-0 

Minimum Time-out 

(40 or 160 MHz) 

0000 

Disabled 

0001 

125 ps 

0010 

250 ps 

0011 

500 ps 

0100 

1 ms 

0101 

2 ms 

0110 

4 ms 

0111 

8 ms 

1000 

16 ms 

1001 

32 ms 

1010 

64 ms 

1011 

128 ms 

1100 

256 ms 

1101 

512 ms 

1110 

1.024 sec 

mi 

2.048 sec 


These values will be correct if the CCF bits in the SCNTL3 
register are set according to the valid combinations in the bit 
description. 


A quadrupled 40 MHz clock is required for Ultra2 SCSI 
operation. 


Bits 3-0 SEL (Selection Time-Out) 

These bits select the SCSI selection/reselection 
time-out period. When this timing (plus the 
200 (is selection abort time) is exceeded, the 
STO bit in the SISTl register is set. For a 
more detailed explanation of interrupts, refer 
to Chapter 2, “Functional Description.” 
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Register 49 (C9) 

SCSI Timer One (STIME1) 
Read/Write 


RES 

HTHBA 

GENSF 

HTHSF 

GEN3 

GEN2 

GEN1 

GEN0 

7 

6 

5 

4 

3 

2 

1 

0 

Defau lt»> 

X 0 

0 

0 

0 

0 

0 

0 


Bit 7 Reserved 

Bit 6 HTHBA (Handshake-to-Handshake 

Timer Bus Activity Enable) 

Setting this bit causes this timer to begin test¬ 
ing for SCSI REQ/ACK activity as soon as 
SBSY/ is asserted, regardless of the agents par¬ 
ticipating in the transfer. 

Bit 5 GENSF (General Purpose Timer 

Scale Factor) 

Setting this bit causes this timer to shift by a 
factor of 16. 


Table 5-10: Time- 

■out Periods, 

50 MHz Clock 

HTH 7-4, SEL 3-0, 
GEN 3-0 

Minimum Time-out 
(50 MHz Clock*) 

GENSF= 0 GENSF=1 

0000 

Disabled 

Disabled 

0001 

100 ps 

1.6 ms 

0010 

200 ps 

3.2 ms 

0011 

400 ps 

6.4 ms 

0100 

800 ps 

12.8 ms 

0101 

1.6 ms 

25.6 ms 

0110 

3.2 ms 

51.2 ms 

0111 

6.4 ms 

102.4 ms 

1000 

12.8 ms 

204.8 ms 

1001 

25.6 ms 

409.6 ms 

1010 

51.2 ms 

819.2 ms 

1011 

102.4 ms 

1.6 sec 

1100 

204.8 ms 

3.2 sec 

1101 

409.6 ms 

6.4 sec 

1110 

819.2 ms 

12.8 sec 

mi 

1.6 sec 

25.6 sec 


These values will be correct if the CCF bits m the SCNTL3 
register are set according to the valid combinations in the bit 
description. 

*50 MHz clock is not supported for Ultra2 SCSI operation. 


Table 5-11: Time-out Periods, 40/160 MHz Clock 

Minimum Time-out 
HTH 7-4, SEL 3-0, (40 or 160 MHz Clock) 

GEN 3-0 

GENSF=0 GENSF=1 


0000 

Disabled 

Disabled 

0001 

125 ps 

2 ms 

0010 

250 ps 

4 ms 

0011 

500 ps 

8 ms 

0100 

1 ps 

16 ms 

0101 

2 ms 

32 ms 

0110 

4 ms 

64 ms 

0111 

8 ms 

128 ms 

1000 

16 ms 

256 ms 

1001 

32 ms 

512 ms 

1010 

64 ms 

1 sec 

1011 

128 ms 

2 sec 

1100 

256 ms 

4.1 sec 

1101 

512 ms 

8.2 sec 

1110 

1.024 sec 

16.4 sec 

mi 

2.048 sec 

32.8 sec 


These values will be correct if the CCF bits in the SCNTL3 
register are set according to the valid combinations in the bit 
description. 

Ultra2 SCSI operation requires a quadrupled 40 MHz 
clock. 
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Bit 4 HTHSF (Handshake to Handshake 
Tinier Scale Factor) 

Setting this bit causes this timer to shift by a 
factor of 16. 

Bits 3-0 GEN3-0 (General Purpose Timer 
Period) 

These bits select the period of the general pur¬ 
pose timer. The time measured is the time 
between enabling and disabling of the timer. 
When this timing is exceeded, the GEN bit in 
the SISTl register is set. Refer to the table 
under STIMEO, bits 3-0, for the available 
time-out periods. 

Note: to reset a timer before it has expired and 
obtain repeatable delays, the time value 
must be written to zero first, and then 
written back to the desired value. This is 
also required when changing from one time 
value to another. See Chapter 2, 
“Functional Description,” for an 
explanation of how interrupts will be 
generated when the timers expire. 


Register 4A (CA) 

Response ID Zero (RESPIDO) 
Read/Write 


Register 4B (CB) 

Response ID One(RESPIDl) 

Read/Write 

RESPIDO and RESPID1 contain the selection or 
reselection IDs. In other words, these two 8-bit reg¬ 
isters contain the ID that the chip responds to on 
the SCSI bus. Each bit represents one possible ID 
with the most significant bit of RESPID1 repre¬ 
senting ID 15 and the least significant bit of 
RESPIDO representing ID 0. The SCID register 
still contains the chip ID used during arbitration. 
The chip can respond to more than one ID because 
more than one bit can be set in the RESPID1 and 
RESPIDO registers. However, the chip can arbi¬ 
trate with only one ID value in the SCID register. 
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Register 4C (CC) 

SCSI Test Zero (STESTO) 
Read Only 


SSAID3 

SSAID2 

SSA1D1 

SSAIDO 

SLT 

ART 

SOZ 

SOM 

7 

6 

5 

4 

3 

2 

1 

0 

Default>» 

0 0 

0 

0 

0 

X 

1 

1 


Bits 7-4 SSAID (SCSI Selected As ID) 

These bits contain the encoded value of the 
SCSI ID that the SYM53C895 was selected or 
reselected as during a SCSI selection or rese¬ 
lection phase. These bits are read only and 
contain the encoded value of 0-15 possible IDs 
that could be used to select the SYM53C895. 
During a SCSI selection or reselection phase 
when a valid ID has been put on the bus, and 
the 53C895 responds to that ID, the “selected 
as” ID is written into these bits. These bits are 
used with the RESPID registers to allow 
response to multiple IDs on the bus. 

Bit 3 SLT (Selection Response Logic Test) 

This bit is set when the SYM53C895 is ready 
to be selected or reselected. This does not take 
into account the bus settle delay of 400 ns. 
This bit is used for functional test and fault 
purposes. 


Bit 1 SOZ (SCSI Synchronous Offset 
Zero) 

This bit indicates that the current synchronous 
SREQ/SACK offset is zero. This bit is not 
latched and may change at any time. It is used 
in low level synchronous SCSI operations. 
When this bit is set, the SYM53C895, as an 
initiator, is waiting for the target to request 
data transfers. If the SYM53C895 is a target, 
then the initiator has sent the offset number of 
acknowledges. 

Bit 0 SOM (SCSI Synchronous Offset 
Maximum) 

This bit indicates that the current synchronous 
SREQ/SACK offset is the maximum specified 
by bits 3-0 in the SCSI Transfer register. This 
bit is not latched and may change at any time. 
It is used in low level synchronous SCSI opera¬ 
tions. When this bit is set, the SYM53C895, as 
a target, is waiting for the initiator to acknowl¬ 
edge the data transfers. If the SYM53C895 is 
an initiator, then the target has sent the offset 
number of requests. 


Bit 2 ART (Arbitration Priority Encoder 
Test) 

This bit will always be set when the 
SYM53C895 exhibits the highest priority ID 
asserted on the SCSI bus during arbitration. It 
is primarily used for chip level testing, but it 
may be used during low level mode operation 
to determine if the SYM53C895 has won arbi¬ 
tration. 
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Register 4D (CD) 

SCSI Test One (STEST1) 
Read/Write 


SCLK 

SISO 

RES 

RES 

Q 

m 

2! 

QSEL 

RES 

RES 

7 

6 

5 

4 

3 

2 

1 

0 

Defau lt»> 

0 0 

X 

X 

0 

0 

X 

X 


Bit 7 SCLK 

This bit, when set, will disable the external 
SCLK (SCSI Clock) pin and the internal SCSI 
Clock Quadrupler, and the chip will use the 
PCI clock as the internal SCSI clock. If a 
transfer rate of 10 MB/s (or 20 MB/s on a wide 
SCSI bus) is to be achieved on the SCSI bus, 
this bit must be reset and at least a 40 MHz 
external SCLK must be provided. 

Bit 6 SISO (SCSI Isolation Mode) 

This bit allows the SYM53C895 to put the 
SCSI bi-directional and input pins into a low 
power mode when the SCSI bus is not in use. 
When this bit is set, the SCSI bus inputs are 
logically isolated from the SCSI bus. 


Quadrupling the SCSI Clock Frequency 

The SYM53C895 SCSI clock quadrupler increases 
the frequency of a 40 MHz SCSI clock to 160 
MHz. Follow these steps to use the clock quadru¬ 
pler: 

1. Set the SCLK Quadrupler Enable bit 
(STESTl, bit 3) 

2. Poll bit 5 of the STEST4 register. The 
SYM53C895 sets this bit as soon as it locks 
in the 160 MHz frequency. The frequency 
lockup takes approximately 100 
microseconds. 

3. Halt the SCSI clock by setting the Halt 
SCSI Clock bit (STEST3 bit 5) 

4. Set the clock conversion factor using the 
SCF and CCF fields in the SCNTL3 
register 

5. Set the SCLK Quadrupler Select bit 
(STESTl, bit2) 

6. Clear the Halt SCSI Clock bit 


Bits 5-4 Reserved 

Bit 3 QEN (SCLK Quadrupler Enable) 

Set this bit to bring the SCSI clock quadrupler 
out of the powered-down state. The default 
value of this bit is clear (SCSI clock quadrupler 
powered down). Set bit 2 after setting this bit, 
to increase the SCLK frequency to 160 MHz. 


Bit 2 QSEL (SCLK Quadrupler Select) 

Set this bit after powering up the SCSI clock 
quadrupler to increase the SCLK frequency to 
160 MHz. This bit has no effect unless bit 3 is 
set. 


Bitsl-0 Reserved 
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Register 4E (CE) 

SCSI Test Two (STEST2) 
Read/Write 


SCE 

ROF 

DIF 

SLB 

SZM 

AWS 

EXT 

LOW 

7 

6 

5 

4 

3 

2 

1 

0 

Detail lt»> 

0 0 

0 

0 

0 

0 

0 

0 


Bit 2 AWS (Always Wide SCSI) 

When this bit is set, all SCSI information 
transfers will be done in 16-bit wide mode. 
This includes data, message, command, status 
and reserved phases. This bit should normally 
be deasserted since 16-bit wide message, com¬ 
mand, and status phases are not supported by 
the SCSI specifications. 


Bit 7 SCE (SCSI Control Enable) 

This bit, when set, allows all SCSI control and 
data lines to be asserted through the SO CL 
and SODL registers regardless of whether the 
SYM53C895 is configured as a target or initia¬ 
tor. 

Note: this bit should not be set during normal 
operation, since it could cause contention 
on the SCSI bus. It is included for 
diagnostic purposes only. 

Bit 6 ROF (Reset SCSI Offset) 

Setting this bit clears any outstanding synchro¬ 
nous SREQ/SACK offset. This bit should be 
set if a SCSI gross error condition occurs, to 
clear the offset when a synchronous transfer 
does not complete successfully. The bit auto¬ 
matically clears itself after resetting the syn¬ 
chronous offset. 

Bit 5 DIF (SCSI Differential Mode) 

Setting this bit allows the SYM53C895 to 
interface properly to external differential trans¬ 
ceivers. Its only real effect is to tri-state the 
SBSY/, SSEL/, and SRST/ pads so that they 
can be used as pure inputs. This bit must be 
cleared for single-ended or LVD operation. 
This bit should be set in the initialization rou¬ 
tine if the high voltage differential interface is 
used. 

Bit 4 SLB (SCSI Loopback Mode) 

Setting this bit allows the SYM53C895 to per¬ 
form SCSI loopback diagnostics.That is, it 
enables the SCSI core to simultaneously per¬ 
form as both initiator and target. 

Bit 3 SZM (SCSI High-Impedance Mode) 

Setting this bit places all the open-drain 
48 mA SCSI drivers into a high-impedance 
state. This is to allow internal loopback mode 
operation without affecting the SCSI bus. 
SYM53C895 Data Manual 


Bit 1 EXT (Extend SREQ/SACK Filter¬ 
ing) 

Symbios TolerANT SCSI receiver technology 
includes a special digital filter on the SREQ/ 
and SACK/ pins which will cause glitches on 
deasserting edges to be disregarded. Setting 
this bit will increase the filtering period from 
30ns to 60ns on the deasserting edge of the 
SREQ/ and SACK/ signals. 

Note: this bit must never be set during fast SCSI 
(greater than 5M transfers per second) 
operations, because a valid assertion could 
be treated as a glitch. 

Note: this bit does not affect the filtering period 
when the Ultra Enable bit in the SCNTL3 
register is set. When the SYM53C895 is 
executing Ultra2 SCSI transfers, the 
filtering period is automatically set at 8 ns. 
When the SYM53C895 is executing Ultra 
SCSI transfers, the filtering period is 
automatically set at 15 ns. 

Bit 0 LOW (SCSI Low level Mode) 

Setting this bit places the SYM53C895 in low 
level mode. In this mode, no DMA operations 
occur, and no SCRIPTS execute. Arbitration 
and selection may be performed by setting the 
start sequence bit as described in the SCNTLO 
register. SCSI bus transfers are performed by 
manually asserting and polling SCSI signals. 
Clearing this bit allows instructions to be exe¬ 
cuted in SCSI SCRIPTS mode. 

Note: it is not necessary to set this bit for access 
to the SCSI bit-level registers (SODL, 
SBCL, and input registers). 
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Register 4F (CF) 

SCSI Test Three (STEST3) 
Read/Write 


TE 

STR 

HSC 

DSI 

SI 6 

TTM 

CSF 

STW 

7 

6 

5 

4 

3 

2 

1 

0 

Defau lt»> 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7 TE (Toler ANT Enable) 

Setting this bit enables the active negation por¬ 
tion of Symbios TolerANT technology. Active 
negation causes the SCSI Request, Acknowl¬ 
edge, Data, and Parity signals to be actively 
deasserted, instead of relying on external pull- 
ups, when the SYM53C895 is driving these 
signals. Active deassertion of these signals will 
occur only when the SYM53C895 is in an 
information transfer phase. When operating in 
a differential environment or at fast SCSI tim¬ 
ings, TolerANT Active negation should be 
enabled to improve setup and deassertion 
times. Active negation is disabled after reset or 
when this bit is cleared. For more information 
on Symbios TolerANT technology, refer to 
Chapter 1. 

Note: this bit must be set if the Ultra Enable bit 
in SCNTL3 is set. 

Note: this bit must be set to use the LVDlink 
transceivers. 

Bit 6 STR (SCSI FIFO Test Read) 

Setting this bit places the SCSI core into a test 
mode in which the SCSI FIFO can be easily 
read. Reading the least significant byte of the 
SODL register will cause the FIFO to unload. 
The functions are summarized in the table 
below. 


Register 

Name 

Register 

Operation 

FIFO Bits 

FIFO 

Function 

SODL 

Read 

15-0 

Unload 

SODLO 

Read 

7-0 

Unload 

SODL1 

Read 

15-8 

None 


Bit 5 HSC (Halt SCSI Clock) 

Asserting this bit causes the internal divided 
SCSI clock to come to a stop in a glitchless 
manner. This bit may be used for test purposes 
or to lower I D j} during a power down mode. 

This bit is used when enabling the SCSI clock 
quadruples For additional information on the 
clock quadrupler, please see “Using the SCSI 
Clock Quadrupler” in Chapter 2. 

Bit 4 DSI (Disable Single Initiator 
Response) 

If this bit is set, the SYM53C895 will ignore all 
bus-initiated selection attempts that employ 
the single-initiator option from SCSI-1. In 
order to select the SYM53C895 while this bit 
is set, the SYM53C895’s SCSI ID and the ini¬ 
tiator’s SCSI ID must both be asserted.This 
bit should be asserted in SCSI-2 systems so 
that a single bit error on the SCSI bus will not 
be interpreted as a single initiator response. 

Bit 3 S16 (16-bit System) 

If this bit is set, all devices in the SCSI system 
implementation are assumed to be 16 bits. This 
causes the SYM53C895 to always check the 
parity bit for SCSI IDs 15-8 during bus-initi¬ 
ated selection or reselection, assuming parity 
checking has been enabled. If an 8-bit SCSI 
device attempts to select the SYM53C895 
while this bit is set, the SYM53C895 will 
ignore the selection attempt, because the parity 
bit for IDs 15-8 will be undriven. See the 
description of the Enable Parity Checking bit 
in the SCNTLO register for more information. 

Bit 2 TTM (Timer Test Mode) 

Asserting this bit facilitates testing of the selec¬ 
tion time-out, general purpose, and hand- 
shake-to-handshake timers by greatly reducing 
all three time-out periods. Setting this bit starts 
all three timers and if the respective bits in the 
SIENl register are asserted, the SYM53C895 
will generate interrupts at time-out. This bit is 
intended for internal manufacturing diagnosis 
and should not be used. 
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Bit 1 CSF (Clear SCSI FIFO) 

Setting this bit will cause the “full flags” for the 
SCSI FIFO to be cleared. This empties the 
FIFO. This bit is self-resetting. In addition to 
the SCSI FIFO pointers, the SIDL, SODL, 
and SODR full bits in the SSTATO and 
SSTAT2 are cleared. 

Bit 0 STW (SCSI FIFO Test Write) 

Setting this bit places the SCSI core into a test 
mode in which the FIFO can easily be read or 
written. While this bit is set, writes to the least 
significant byte of the SODL register will cause 
the entire word contained in this register to be 
loaded into the FIFO. Writing the least signifi¬ 
cant byte of the SODL register will cause the 
FIFO to load.These functions are summarized 
in the table below: 


Register 

Name 

Register 

Operation 

FIFO Bits 

FIFO 

Function 

SODL 

Write 

15-0 

Load 

SODLO 

Write 

7-0 

Load 

SODL1 

Write 

15-8 

None 


Register 50-51 (D0-D1) 

SCSI Input Data Latch (SIDL) 

Read Only 

This register is used primarily for diagnostic testing, 
programmed I/O operation, or error recovery. Data 
received from the SCSI bus can be read from this 
register. Data can be written to the SODL register 
and then read back into the SYM53C895 by read¬ 
ing this register to allow loopback testing. When re¬ 
ceiving SCSI data, the data will flow into this 
register and out to the host FIFO. This register dif¬ 
fers from the SBDL register; SIDL contains latched 
data and the SBDL always contains exactly what is 
currently on the SCSI data bus. Reading this regis¬ 
ter causes the SCSI parity bit to be checked, and 
will cause a parity error interrupt if the data is not 
valid. The power-up values are indeterminate. 
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Register 52 (D2) 

SCSI Test 4 (STEST4) 
Read Only 


SMODE 

LOCK 

RES 

RES 

RES 

RES 

RES 

7 L 6 

5 

4 

3 

2 

1 

0 

Default»> 

X X 

0 

X 

X 

X 

X 

X 


Bit 7-6 SMODE (SCSI Mode) 

These bits contain the encoded value of the 
SCSI operating mode that is indicated by the 
voltage level sensed at the DIFFSENS pin. The 
incoming SCSI signal goes to a pair of analog 
comparators that determine the voltage win¬ 
dow of the DIFFSENS signal. These voltage 
windows indicate LVD, single-ended, or high- 
power differential operation. The bit values are 
defined in Table 5-12. 

Table 5-12: DIFFSENS Voltage Levels and SCSI 
Operating Modes 


Bit 7, Bit 6 

Operating Mode 

00 

Not possible 

01 

high voltage differential or powered 
down (for high voltage differential 
mode, the DIF bit must also be set) 

10 

Single-ended 

11 

LVD SCSI 


Bit 5 LOCK (Frequency Lock) 

This bit is used when enabling the SCSI clock 
quadrupler, which allows the SYM53C895 to 
transfer data at Ultra2 SCSI rates. Poll this bit 
for a 1 to determine that the clock quadrupler 
has locked to 160 MHz. For more information 
on enabling the clock quadrupler, refer to the 
descriptions for STESTl, bits 2 and 3. 

Bits 4-0 Reserved 


Registers 54-55 (D4-D5) 

SCSI Output Data Latch (SODL) 
Read/Write 

This register is used primarily for diagnostic testing 
or programmed I/O operation. Data written to this 
register is asserted onto the SCSI data bus by set¬ 
ting the Assert Data Bus bit in the SCNTL1 regis¬ 
ter. This register is used to send data via 
programmed I/O. Data flows through this register 
when sending data in any mode. It is also used to 
write to the synchronous data FIFO when testing 
the chip. The power-up value of this register is in¬ 
determinate. 
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Registers 58-59 (D8-D9) 

SCSI Bus Data Lines (SBDL) 

Read Only 

This register contains the SCSI data bus status. 
Even though the SCSI data bus is active low, these 
bits are active high. The signal status is not latched 
and is a true representation of exactly what is on the 
data bus at the time the register is read. This regis¬ 
ter is used when receiving data via programmed 
I/O. This register can also be used for diagnostic 
testing or in low level mode. The power-up value of 
this register is indeterminate. 


Registers 5C-5F (DC-DF) 

Scratch Register B (SCRATCHB) 
(Read/Write) 

This is a general purpose user definable scratch pad 
register. Apart from CPU access, only Register 
Read/Write and Memory Moves directed at the 
SCRATCH register will alter its contents. The 
SYM53C895 cannot fetch SCRIPTS instructions 
from this location.When bit 3 in the CTEST2 reg¬ 
ister is set, this register contains the base address for 
the 4 KB internal RAM. Setting CTEST2 bit 3 
only causes the base address to appear in the 
SCRATCHB register; any information that was 
previously in the register will remain intact. Any 
writes to this register while the bit is set will pass 
through to the actual SCRATCHB register. The 
power-up values are indeterminate. 
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Registers 60h-7Fh (EOh-FFh) 

Scratch Registers C-J 
(SCRATCHC-SCRATCHJ) 

Read/Write 

These registers are general-purpose scratch regis¬ 
ters for user-defined functions. The SYM53C895 
cannot fetch SCRIPTS instructions from this loca- 
tion.The power-up value of these registers is inde¬ 
terminate. 
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Chapter 6 

Instruction Set of the I/O Processor 


After power up and initialization of the 
SYM53C895, the chip may be operated in the low 
level register interface mode, or using SCSI 
SCRIPTS. 

With the low level register interface, the user has 
access to the DMA control logic and the SCSI bus 
control logic. An external processor has access to 
the SCSI bus signals and the low level DMA sig¬ 
nals, which allows creation of complicated board 
level test algorithms. The low level interface is use¬ 
ful for backward compatibility with SCSI devices 
that require certain unique timings or bus 
sequences to operate properly. Another feature 
allowed at the low level is loopback testing. In 
loopback mode, the SCSI core can be directed to 
talk to the DMA core to test internal data paths all 
the way out to the chip’s pins. 


SCSI SCRIPTS 

To operate in the SCSI SCRIPTS mode, the 
SYM53C895 requires only a SCRIPTS start 
address. The start address must be at a dword 
(four byte) boundary. This will align all the follow¬ 
ing SCRIPTS at a dword boundary since all 
SCRIPTS are 8 or 12 bytes long. Instructions are 
fetched until an interrupt instruction is encoun¬ 
tered, or until an unexpected event (such as a 
hardware error) causes an interrupt to the external 
processor. 

Once an interrupt is generated, the SYM53C895 
halts all operations until the interrupt is serviced. 
Then, the start address of the next SCRIPTS 
instruction may be written to the DMA SCRIPTS 
Pointer register to restart the automatic fetching 
and execution of instructions. 


The SCSI SCRIPTS mode of execution allows the 
SYM53C895 to make decisions based on the sta¬ 
tus of the SCSI bus, which off-loads the micropro¬ 
cessor from servicing the numerous interrupts 
inherent in I/O operations. 

Given the rich set of SCSI-oriented features 
included in the instruction set, and the ability to 
re-enter the SCSI algorithm at any point, this high 
level interface is all that is required for both normal 
and exception conditions. Switching to low level 
mode for error recovery should never be required. 

The following types of SCRIPTS instructions are 
implemented in the SYM53C895: 

■ Block Move—used to move data between the 
SCSI bus and memory 

■ I/O or Read/Write—causes the SYM53C895 
to trigger common SCSI hardware sequences, 
or to move registers 

■ Transfer Control—allows SCRIPTS 
instructions to make decisions based on real 
time SCSI bus conditions 

■ Memory Move—causes the SYM53C895 to 
execute block moves between different parts of 
main memory 

■ Load and Store—provides a more efficient way 
to move data to/from memory from/to an 
internal register in the chip without using the 
Memory Move instruction 

Each instruction consists of two or three 32-bit 
words.The first 32-bit word is always loaded into 
the DCMD and DBC registers, the second into 
the DSPS register. The third word, used only by 
Memory Move instructions, is loaded into the 
TEMP shadow register. In an indirect I/O or Move 
instruction, the first two 32-bit op code fetches will 
be followed by one or two more 32-bit fetch cycles. 
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Sample Operation 

The following example describes execution of a 

SCRIPTS instruction.This sample operation is for 

a Block Move instruction. 

1. The host CPU, through programmed I/O, 
gives the DMA SCRIPTS Pointer (DSP) 
register (in the Operating Register file) the 
starting address in main memory that points to 
a SCSI SCRIPTS program for execution. 

2. Loading the DSP register causes the 
SYM53C895 to fetch its first instruction at the 
address just loaded. This will be from main 
memory or the internal RAM, depending on 
the address. 

3. The SYM53C895 typically fetches two dwords 
(64 bits) and decodes the high order byte of 
the first longword as a SCRIPTS instruction. If 
the instruction is a Block Move, the lower three 
bytes of the first longword are stored and 
interpreted as the number of bytes to be 
moved.The second longword is stored and 
interpreted as the 32-bit beginning address in 
main memory to which the move is directed. 

4. For a SCSI send operation, the SYM53C895 
waits until there is enough space in the DMA 
FIFO to transfer a programmable size block of 
data. For a SCSI receive operation, it waits 
until enough data is collected in the DMA 
FIFO for transfer to memory. At this point, the 
SYM53C895 requests use of the PCI bus 
again to transfer the data. 

5. When the SYM53C895 is granted the PCI 
bus, it will execute (as a bus master) a burst 
transfer (programmable size) of data, 
decrement the internally stored remaining byte 
count, increment the address pointer, and then 
release the PCI bus.The SYM53C895 stays off 
the PCI bus until the FIFO can again hold (for 
a write) or has collected (for a read) enough 
data to repeat the process. 


The process repeats until the internally stored byte 
count has reached zero.The SYM53C895 releases 
the PCI bus and then performs another SCRIPTS 
instruction fetch cycle, using the incremented 
stored address maintained in the DMA SCRIPTS 
Pointer register. Execution of SCRIPTS instruc¬ 
tions continues until an error condition occurs or 
an interrupt SCRIPTS instruction is received. At 
this point, the SYM53C895 interrupts the host 
CPU and waits for further servicing by the host 
system. It can execute independent Block Move 
instructions specifying new byte counts and start¬ 
ing locations in main memory. In this manner, the 
SYM53C895 performs scatter/gather operations 
on data without requiring help from the host pro¬ 
gram, generating a host interrupt, or requiring an 
external DMA controller to be programmed. 
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System Processor 


System Memory 


SCSI Initiator Write Example 
select ATN 0, alt_addr 

move from identify_msgjntf, when MSG_Olf' 
move from cmd_buf, when CMD 
move from data_buf, when DATA_OUT 
move from statjnjnif, when STATUS 
move from msgjn^buf, when MSG_IN 
move SCNTL2&7F to SCNTL2 
clear ACK 
wait disconnect alt2 

intlO_ 



Table 


byte count 
address 


byte count 
address 


byte count 
address 


byte count 
address 


•-•Message Buffer 
-•Command Buffer 
1 —*Data Buffer 
Status Buffer 


B 

U 

s 


Fetch 

SCRIPTS 



SYM53C895 

SCSI 


Bus 


Figure 6-1: SCRIPTS Overview 
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Block Move Instructions 

For Block Move instructions, bits 5 and 4 (SIOM 
and DIOM) in the DMODE register determine 
whether the source/destination address resides in 
memory or I/O space. When data is being moved 
onto the SCSI bus, SIOM controls whether that 
data comes from I/O or memory space. When data 
is being moved off of the SCSI bus, DIOM con¬ 
trols whether that data goes to I/O or memory 
space. 


First Dword 

Bits 31-30 Instruction Type-Block Move 
Bit 29 Indirect Addressing 

When this bit is cleared, user data is moved to 
or from the 32-bit data start address for the 
Block Move instruction. The value is loaded 
into the chip’s address register and incre¬ 
mented as data is transferred.The address of 
the data to be moved is in the second dword of 
this instruction. 


Once the data pointer address is loaded, it is 
executed as when the chip operates in the 
direct mode. This indirect feature allows a 
table of data buffer addresses to be specified. 
Using the Symbios Logic SCSI SCRIPTS 
assembler, the table offset is placed in the 
script at compile time. Then at the actual data 
transfer time, the offsets are added to the base 
address of the data address table by the exter¬ 
nal processor. The logical I/O driver builds a 
structure of addresses for an I/O rather than 
treating each address individually. This feature 
makes it possible to locate SCSI SCRIPTS in a 
PROM. 

Note: indirect and table indirect addressing 

cannot be used simultaneously; only one 
addressing method may be used at a time. 

Bit 28 Table Indirect 

When this bit is set, the 24-bit signed value in 
the start address of the move is treated as a rel¬ 
ative displacement from the value in the DSA 
register. Both the transfer count and the 
source/destination address are fetched from 
this address. 


When set, the 32-bit user data start address for 
the Block Move is the address of a pointer to 
the actual data buffer address.The value at the 
32-bit start address is loaded into the chip’s 
DNAD register via a third longword fetch (4- 
byte transfer across the host computer bus). 

Direct 

The byte count and absolute address are as 


follows. 


Command 

Byte Count 

Address of Data 


Use the signed integer offset in bits 23-0 of the 
second four bytes of the instruction, added to 
the value in the DSA register, to fetch first the 
byte count and then the data address.The 
signed value is combined with the data struc¬ 
ture base address to generate the physical 
address used to fetch values from the data 
structure. Sign-extended values of all ones for 
negative values are allowed, but bits 31-24 are 
ignored. 


Command 

Not Used 

Don’t Care 

Table Offset 


Indirect Note: indirect and table indirect addressing 

Use the fetched byte count, but fetch the data cannot be used simultaneously; only one 

address from the address in the instruction. addressing method may be used at a time. 


Command 

Byte Count 

Address of Pointer to Data 
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Figure 6-2: Block Move Instruction Register 


Prior to the start of an I/O, the Data Structure SCRIPTS can directly execute operating sys- 

Base Address register (DSA) should be loaded tem I/O data structures, saving time at the 

with the base address of the I/O data structure. beginning of an I/O operation. The I/O data 

The address may be any address on a long structure can begin on any longword boundary 

word boundary. and may cross system segment boundaries. 

After a Table Indirect op code is fetched, the There are two restrictions on the placement of 

DSA is added to the 24-bit signed offset value pointer data in system memory: the eight bytes 

from the op code to generate the address of the of data in the MOVE instruction must be con- 

required data; both positive and negative off- tiguous, as shown below; and indirect data 

sets are allowed. A subsequent fetch from that fetches are not available during execution of a 

address brings the data values into the chip. Memory-to-Memory DMA operation. 

For a MOVE instruction, the 24-bit byte 
count is fetched from system memory. Then 
the 32-bit physical address is brought into the 
SYM53C895. Execution of the move begins at 
this point. 
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Bit 27 Op Code 

This 1-bit field defines the instruction to be 
executed as a block move (MOVE). 


Target Mode 


OPC 

Instruction Defined 

0 

MOVE 

1 

CHMOV 


1. The SYM53C895 verifies that it is connected 
to the SCSI bus as a target before executing 
this instruction. 

2. The SYM53C895 asserts the SCSI phase 
signals (SMSG/, SC_D/, and SI_0/) as defined 
by the Phase Field bits in the instruction. 

3. If the instruction is for the command phase, 
the SYM53C895 receives the first command 
byte and decodes its SCSI Group Code. 

a) If the SCSI Group Code is either Group 0, 
Group 1, Group 2, or Group 5, and if the 
Vendor Unique Enhancement 1 (VUE1) 
bit (SCNTL2 bit 1) is clear, then the 
SYM53C895 overwrites the DBG register 
with the length of the Command 
Descriptor Block: 6, 10, or 12 bytes. 

b) If the Vendor Unique Enhancement 1 
(VUEl) bit (SCNTL2 bit 1) is set, the 
SYM53C895 receives the number of bytes 
in the byte count regardless of the group 
code. 

c) If the Vendor Unique Enhancement 1 bit is 
clear and group code is vendor unique, the 
SYM53C895 receives the number of bytes 
in the count. 

d) If any other Group Code is received, the 
DBC register is not modified and the 
SYM53C895 will request the number of 
bytes specified in the DBC register. If the 
DBC register contains OOOOOOh, an illegal 
instruction interrupt is generated. 

4. The SYM53C895 transfers the number of 


bytes specified in the DBC register starting at 
the address specified in the DNAD register. If 
the Op Code bit is set and a data transfer ends 
on an odd byte boundary, the SYM53C895 
will store the last byte in the SCSI Wide 
Residue Data Register during a receive 
operation. This byte will be combined with the 
first byte from the subsequent transfer so that a 
wide transfer can be completed. 

5. If the SATN/ signal is asserted by the initiator 
or a parity error occurred during the transfer, 
the transfer can optionally be halted and an 
interrupt generated. The Disable Halt on 
Parity Error or ATN bit in the SCNTLl 
register controls whether the SYM53C895 will 
halt on these conditions immediately, or wait 
until completion of the current Move. 


Initiator Mode 


OPC 

Instruction Defined 

0 

CHMOV 

1 

MOVE 


1. The SYM53C895 verifies that it is connected 
to the SCSI bus as an initiator before executing 
this instruction. 

2. The SYM53C895 waits for an unserviced 
phase to occur. An unserviced phase is defined 
as any phase (with SREQ/ asserted) for which 
the SYM53C895 has not yet transferred data 
by responding with a SACK/. 

3. The SYM53C895 compares the SCSI phase 
bits in the DCMD register with the latched 
SCSI phase lines stored in the SSTATl 
register. These phase lines are latched when 
SREQ/ is asserted. 

4. If the SCSI phase bits match the value stored 
in the SSTATl register, the SYM53C895 will 
transfer the number of bytes specified in the 
DBC register starting at the address pointed to 
by the DNAD register. If the op code bit is 
cleared and a data transfer ends on an odd byte 
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boundary, the SYM53C895 will store the last 
byte in the SCSI Wide Residue Data Register 
during a receive operation, or in the SCSI 
Output Data Latch Register during a send 
operation.This byte will be combined with the 
first byte from the subsequent transfer so that a 
wide transfer can be completed. 

5. If the SCSI phase bits do not match the value 
stored in the SSTATl register, the 
SYM53C895 generates a phase mismatch 
interrupt and the instruction is not executed. 

6. During a Message Out phase, after the 
SYM53C895 has performed a select with 
Attention (or SATN/ has been manually 
asserted with a Set ATN instruction), the 
SYM53C895 will deassert SATN/ during the 
final SREQ/SACK handshake. 

7. When the SYM53C895 is performing a block 
move for Message In phase, it will not deassert 
the SACK/ signal for the last SREQ/SACK 
handshake. The SACK signal must be cleared 
using the Clear SACK I/O instruction. 

Bits 26-24 SCSI Phase 

This 3-bit field defines the desired SCSI infor¬ 
mation transfer phase. When the SYM53C895 
operates in initiator mode, these bits are com¬ 
pared with the latched SCSI phase bits in the 
SSTATl register. When the SYM53C895 
operates in target mode, the SYM53C895 
asserts the phase defined in this field. The fol¬ 
lowing table describes the possible combina¬ 
tions and the corresponding SCSI phase. 


MSG 

C/D 

I/O 

SCSI Phase 

0 

0 

0 

Data out 

0 

0 

1 

Data in 

0 

1 

0 

Command 

0 

1 

1 

Status 

1 

0 

0 

Reserved out 

1 

0 

1 

Reserved in 

1 

1 

0 

Message out 

1 

1 

1 

Message in 


Bits 23-0 Transfer Counter 

This 24-bit field specifies the number of data 
bytes to be moved between the SYM53C895 
and system memory. The field is stored in the 
DBC register. When the SYM53C895 trans¬ 
fers data to/ffom memory, the DBC register is 
decremented by the number of bytes trans¬ 
ferred. In addition, the DNAD register is 
incremented by the number of bytes trans¬ 
ferred. This process is repeated until the DBC 
register has been decremented to zero. At that 
time, the SYM53C895 fetches the next 
instruction. 

If bit 28 is set, indicating table indirect 
addressing, this field is not used. The byte 
count is instead fetched from a table pointed to 
by the DSA register. 
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Second Dword 

Bits 31-0 Start Address 

This 32-bit field specifies the starting address 
of the data to be moved to/from memory. This 
field is copied to the DNAD register. When the 
SYM53C895 transfers data to or from mem¬ 
ory, the DNAD register is incremented by the 
number of bytes transferred. 

When bit 29 is set, indicating indirect address¬ 
ing, this address is a pointer to an address in 
memory that points to the data location. When 
bit 28 is set, indicating table indirect address¬ 
ing, the value in this field is an offset into a 
table pointed to by the DSA. The table entry 
contains byte count and address information. 


I/O Instructions 


First Dword 

Bits 31-30 Instruction Type - I/O Instruction 
Bits 29-27 Op Code 

The following Op Code bits have different 
meanings, depending on whether the 
SYM53C895 is operating in initiator or target 
mode. Note: Op Code selections 101-111 are 
considered Read/Write instructions, and are 
described in that section. 


Target Mode 


0PC2 

0PC1 

QPCO 

Instruction Defined 

0 

0 

0 

Reselect 

0 

0 

1 

Disconnect 

0 

1 

0 

Wait Select 

0 

1 

1 

Set 

1 

0 

0 

Clear 


Reselect Instruction 

1. The SYM53C895 arbitrates for the SCSI bus 
by asserting the SCSI ID stored in the SCID 
register. If the SYM53C895 loses arbitration. 


then it tries again during the next available 
arbitration cycle without reporting any lost 
arbitration status. 

2. If the SYM53C895 wins arbitration, it 
attempts to reselect the SCSI device whose ID 
is defined in the destination ID field of the 
instruction. Once the SYM53C895 has won 
arbitration, it fetches the next instruction from 
the address pointed to by the DSP register. 
Therefore, the SCRIPTS can move on to the 
next instructions before the reselection has 
completed. It will continue executing 
SCRIPTS until a SCRIPT that requires a 
response from the initiator is encountered. 

3. If the SYM53C895 is selected or reselected 
before winning arbitration, it fetches the next 
instruction from the address pointed to by the 
32-bit jump address field stored in the DNAD 
register.The SYM53C895 should manually be 
set to initiator mode if it is reselected, or to 
target mode if it is selected. 

Disconnect Instruction 

The SYM53C895 disconnects from the SCSI bus 

by deasserting all SCSI signal outputs. 

Wait Select Instruction 

1. If the SYM53C895 is selected, it fetches the 
next instruction from the address pointed to by 
the DSP register. 

2. If reselected, the SYM53C895 fetches the next 
instruction from the address pointed to by the 
32-bit jump address field stored in the DNAD 
register.The SYM53C895 should manually be 
set to initiator mode when reselected. 

3. If the CPU sets the SIGP bit in the ISTAT 
register, the SYM53C895 will abort the Wait 
Select instruction and fetch the next 
instruction from the address pointed to by the 
32-bit jump address field stored in the DNAD 
register. 

Set Instruction 

When the SACK/ or SATN/ bits are set, the corre¬ 
sponding bits in the SO CL register are set. SACK/ 

or SATN/ should not be set except for testing pur- 
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poses. When the target bit is set, the corresponding 
bit in the SCNTLO register is also set. When the 
carry bit is set, the corresponding bit in the Arith¬ 
metic Logic Unit (ALU) is set. 

Note: None of the signals are set on the SCSI bus 
in target mode. 

Clear Instruction 

When the SACK/ or SATN/ bits are set, the corre¬ 
sponding bits are cleared in the SOCL register. 
SACK/ or SATN/ should not be set except for test¬ 
ing purposes. When the target bit is set, the corre¬ 
sponding bit in the SCNTLO register is cleared. 
When the carry bit is set, the corresponding bit in 
the ALU is cleared. 

Note: the Clear instruction does not cause any of 
the SCSI bus signals to be reset when the 
SYM53C895 is in target mode. 
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Initiator Mode 


0PC2 

0PC1 

OPCO 

Instruction Defined 

0 

0 

0 

Select 

0 

0 

1 

Wait Disconnect 

0 

1 

0 

Wait Reselect 

0 

1 

1 

Set 

1 

0 

0 

Clear 


Select Instruction 

1. The SYM53C895 arbitrates for the SCSI bus 
by asserting the SCSI ID stored in the SCID 
register. If the SYM53C895 loses arbitration, 
it tries again during the next available 
arbitration cycle without reporting any lost 
arbitration status. 

2. If the SYM53C895 wins arbitration, it 
attempts to select the SCSI device whose ID is 
defined in the destination ID field of the 
instruction. Once the SYM53C895 has won 
arbitration, it fetches the next instruction from 
the address pointed to by the DSP register. 
Therefore, the scripts can move to the next 
instruction before the selection has completed. 
It will continue executing SCRIPTS until a 
SCRIPT that requires a response from the 
target is encountered. 

3. If the SYM53C895 is selected or reselected 
before winning arbitration, it fetches the next 
instruction from the address pointed to by the 
32-bit jump address field stored in the DNAD 
register.The SYM53C895 should manually be 
set to initiator mode if it is reselected, or to 
target mode if it is selected. 

4. If the Select with SATN/ field is set, the 
SATN/ signal is asserted during the selection 
phase. 


Wait Disconnect Instruction 

The SYM53C895 waits for the target to perform a 
“legal” disconnect from the SCSI bus. A “legal” 
disconnect occurs when SBSY/ and SSEL/ are 
inactive for a minimum of one Bus Free delay (400 
ns), after the SYM53C895 has received a Discon¬ 
nect Message or a Command Complete Message. 

Wait Reselect Instruction 

1. If the SYM53C895 is selected before being 
reselected, it fetches the next instruction from 
the address pointed to by the 32-bit jump 
address field stored in the DNAD register. The 
SYM53C895 should be manually set to target 
mode when selected. 

2. If the SYM53C895 is reselected, it fetches the 
next instruction from the address pointed to by 
the DSP register. 

3. If the CPU sets the SIGP bit in the ISTAT 
register, the SYM53C895 will abort the Wait 
Reselect instruction and fetch the next 
instruction from the address pointed to by the 
32-bit jump address field stored in the DNAD 
register. 

Set Instruction 

When the SACK/ or SATN/ bits are set, the corre¬ 
sponding bits in the SOCL register are set. When 
the target bit is set, the corresponding bit in the 
SCNTLO register is also set. When the carry bit is 
set, the corresponding bit in the ALU is set. 

Clear Instruction 

When the SACK/or SATN/ bits are set, the corre¬ 
sponding bits are cleared in the SOCL register. 
When the target bit is set, the corresponding bit in 
the SCNTLO register is cleared. When the carry 
bit is set, the corresponding bit in the ALU is 
cleared. 

Bit 26 Relative Addressing Mode 

When this bit is set, the 24-bit signed value in 
the DNAD register is used as a relative dis¬ 
placement from the current DSP address. This 
bit should only be used in conjunction with the 
Select, Reselect, Wait Select, and Wait Reselect 
instructions. The Select and Reselect instruc¬ 
tions can contain an absolute alternate jump 
address or a relative transfer address. 
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I/O Instructions 


Bit 25 Table Indirect Mode 

When this bit is set, the 24-bit signed value in 
the DBC register is added to the value in the 
DSA register, used as an offset relative to the 
value in the Data Structure Base Address 
(DSA) register. The SCNTL3 value, SCSI ID, 
synchronous offset and synchronous period are 
loaded from this address. Prior to the start of 
an I/O, the DSA should be loaded with the 
base address of the I/O data structure. The 
address may be any address on a longword 
boundary. After a Table Indirect op code is 
fetched, the DSA is added to the 24-bit signed 
offset value from the op code to generate the 
address of the required data; both positive and 
negative offsets are allowed. A subsequent 
fetch from that address brings the data values 
into the chip. 

SCRIPTS can directly execute operating sys¬ 
tem I/O data structures, saving time at the 
beginning of an I/O operation. The I/O data 
structure can begin on any longword boundary 
and may cross system segment boundaries. 
There are two restrictions on the placement of 
data in system memory: 

1. The I/O data structure must lie within the 8 
MB above or below the base address. 

2. An I/O command structure must have all four 
bytes contiguous in system memory, as shown 
below. The offset/period bits are ordered as in 
the SXFER register. The configuration bits are 
ordered as in the SCNTL3 register. 


Config 

ID 

Offset/ 

period 

(00) 


This bit should only be used in conjunction 
with the Select, Reselect, Wait Select, and Wait 
Reselect instructions. Bits 25 and 26 may be 
set individually or in combination: 



Bit 25 

Bit 26 

Direct 

0 

0 

Table Indirect 

0 

1 

Relative 

1 

0 

Table Relative 

1 

1 


Direct 

Uses the device ID and physical address in the 
instruction. 


Com¬ 

mand 

ID 

Not Used 

Not Used 

Absolute Alternate Address 


Table Indirect 

Uses the physical jump address, but fetches data 
using the table indirect method. 


Command 

Table Offset 

Absolute Alternate Address 

Relative 



Uses the device ID in the instruction, but treats 
the alternate address as a relative jump 


Com¬ 

mand 

ID 

Not Used 

Not 

Used 

Alternate Jump Offset 


Table Relative 

Treats the alternate jump address as a relative 
jump and fetches the device ID, synchronous off¬ 
set, and synchronous period indirectly. Adds the 
value in bits 23-0 of the first four bytes of the 
SCRIPTS instruction to the data structure base 
address to form the fetch address. 


Command 

Table Offset 

Alternate Jump Offset 
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Read/Write Instructions 


Bit 24 Select with ATN/ 

This bit specifies whether SATN/ will be 
asserted during the selection phase when the 
SYM53C895 is executing a Select instruction. 
When operating in initiator mode, set this bit 
for the Select instruction. If this bit is set on 
any other I/O instruction, an illegal instruction 
interrupt is generated. 

Bit 23-20 Reserved 

Bits 19-16 Encoded SCSI Destination ID 

This 4-bit field specifies the destination SCSI 
ID for an I/O instruction. 

Bits 15-llReserved 
Bit 10 Set/Clear Carry 

This bit is used in conjunction with a Set or 
Clear instruction to set or clear the Carry bit. 
Setting this bit with a Set instruction asserts 
the Carry bit in the ALU. Setting this bit with a 
Clear instruction deasserts the Carry bit in the 
ALU. 

Bits 8-7 Reserved 

Bit 9 Set/Clear Target Mode 

This bit is used in conjunction with a Set or 
Clear instruction to set or clear target mode. 
Setting this bit with a Set instruction config¬ 
ures the SYM53C895 as a target device (this 
sets bit 0 of the SCNTLO register). Setting this 
bit with a Clear instruction configures the 
SYM53C895 as an initiator device (this clears 
bit 0 of the SCNTLO register). 

Bit 6 Set/Clear SACK/ 

Bit 3 Set/Clear SATN/ 

These two bits are used in conjunction with a 
Set or Clear instruction to assert or deassert 
the corresponding SCSI control signal. Bit 6 
controls the SCSI SACK/ signal; bit 3 controls 
the SCSI SATN/ signal. 

Setting either of these bits will set or reset the 
corresponding bit in the SOCL register, 
depending on the instruction used. The Set 
instruction is used to assert SACK/ and/or 
SATN/ on the SCSI bus. The Clear instruction 
is used to deassert SACK/ and/or SATN/ on 
the SCSI bus. 


Since SACK/ and SATN/ are initiator signals, 
they will not be asserted on the SCSI bus 
unless the SYM53C895 is operating as an initi¬ 
ator or the SCSI Loopback Enable bit is set in 
the STEST2 register. 

The Set/Clear SCSI ACK/ATN instruction 
would be used after message phase Block Move 
operations to give the initiator the opportunity 
to assert attention before acknowledging the 
last message byte. For example, if the initiator 
wishes to reject a message, an Assert SCSI 
ATN instruction would be issued before a 
Clear SCSI ACK instruction. 

Bits 2-0 Reserved 


Second Dword 

Bits 31-0 Start Address 

This 32-bit field contains the memory address 
to fetch the next instruction if the selection or 
reselection fails. 

If relative or table relative addressing is used, 
this value is a 24-bit signed offset relative to the 
current DSP register value. 


Read/Write Instructions 

The Read/Write instruction supports addition, 
subtraction, and comparison of two separate values 
within the chip. It performs the desired operation 
on the specified register and the SFBR register, 
then stores the result back to the specified register 
or the SFBR. 


First Dword 

Bits 31-30 Instruction Type - Read/Write 
Instruction 

The Read/Write instruction uses operator bits 
26 through 24 in conjunction with the op code 
bits to determine which instruction is currently 
selected. 
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Instruction Set of the I/O Processor 

Read/Write Instructions 


Bits 29-27 Op Code 

The combinations of these bits determine if the 
instruction is a Read/Write or an I/O instruc¬ 
tion. Op codes 000 through 100 are considered 
I/O instructions. 

Bits 26-24 Operator 

These bits are used in conjunction with the op 
code bits to determine which instruction is 
currently selected. Refer to table 6-1 for field 
definitions. 

Bit 23 Use data8/SFBR 

When this bit is set, SFBR will be used instead 
of the data8 value during a Read-Modify-Write 
instruction (see Table 6-1).This allows the 
user to add two register values. 

Bits 22-16 Register Address - A(6-0) 

Register values may be changed from 
SCRIPTS in read-modify-write cycles or move 
to/from SFBR cycles. A(6-0) select an 8-bit 
source/destination register within the 
SYM53C895. 

Bits 15-8 Immediate Data 

This 8-bit value is used as a second operand in 
logical and arithmetic functions. 

Bits 7-0 Reserved 


Second Dword 

Bits 31-0 Destination Address 

This field contains the 32-bit destination 
address where the data is to be moved. 


Read-Modify-Write 

Cycles 

During these cycles the register is read, the 
selected operation is performed, and the result is 
written back to the source register. 


The Add operation can be used to increment or 
decrement register values (or memory values if 
used in conjunction with a Memory-to-Register 
Move operation) for use as loop counters. 

Subtraction is not available when SFBR is used 
instead of data8 in the instruction syntax. To sub¬ 
tract one value from another when using SFBR, 
first XOR the value to subtract (subtrahend) with 
OxFF, and add 1 to the resulting value.This creates 
the 2’s compliment of the subtrahend. The two val¬ 
ues can then be added to obtain the difference. 


Move to/from 
SFBR Cycles 

All operations are read-modify-writes. However, 
two registers are involved, one of which is always 
the SFBR. The possible functions of this instruc¬ 
tion are: 

■ Write one byte (value contained within the 
SCRIPTS instruction) into any chip register. 

■ Move to/from the SFBR from/to any other 
register. 

■ Alter the value of a register with AND/OR/ 
ADD/XOR/SHIFT LEFT/SHIFT RIGHT 
operators. 

■ After moving values to the SFBR, the compare 
and jump, call, or similar instructions may be 
used to check the value. 

■ A Move-to-SFBR followed by a Move-from- 
SFBR can be used to perform a register to 
register move. 
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Read/Write Instructions 



Table 6-1: 

ReadVWrite Instructions 


Operator 

Op Code 111 

Read Modify Write 

0p Code 110 

Move to SFBR 

0p Code 101 

Move from SFBR 

000 

Move data into register. 
Syntax: “Move data8 to 

RegA” 

Move data into SFBR regis¬ 
ter. Syntax: “Move data8 to 
SFBR” 

Move data into register. 
Syntax: “Move data8 to 

RegA” 

001* 

Shift register one bit to the 
left and place the result in 
the same register. Syntax: 
“Move RegA SHL RegA” 

Shift register one bit to the 
left and place the result in 
the SFBR register. Syntax: 
“Move RegA SHL SFBR” 

Shift the SFBR register one 
bit to the left and place the 
result in the register. Syntax: 
“Move SFBR SHL RegA” 

010 

OR data with register and 
place the result in the same 
register. Syntax: “Move 

RegA | data8 to RegA” 

OR data with register and 
place the result in the SFBR 
register. Syntax: “Move 

RegA | data8 to SFBR” 

OR data with SFBR and 
place the result in the regis¬ 
ter. Syntax: “Move SFBR | 
data8 to RegA” 

Oil 

XOR data with register and 
place the result in the same 
register. Syntax: “Move 

RegA XOR data8 to RegA” 

XOR data with register and 
place the result in the SFBR 
register. Syntax: “Move 

RegA XOR data8 to SFBR” 

XOR data with SFBR and 
place the result in the regis¬ 
ter. Syntax: “Move SFBR 
XOR data8 to RegA” 

100 

AND data with register and 
place the result in the same 
register. Syntax: “Move 

RegA & data8 to RegA” 

AND data with register and 
place the result in the SFBR 
register. Syntax: “Move 

RegA & data8 to SFBR” 

AND data with SFBR and 
place the result in the regis¬ 
ter. Syntax: “Move SFBR & 
data8 to RegA” 

101* 

Shift register one bit to die 
right and place the result in 
the same register. Syntax: 
“Move RegA SHR RegA” 

Shift register one bit to the 
right and place the result in 
the SFBR register. Syntax: 
“Move RegA SHR SFBR” 

Shift the SFBR register one 
bit to the right and place the 
result in the register. Syntax: 
“Move SFBR SHR RegA” 

110 

Add data to register without 
carry and place the result in 
the same register. Syntax: 
“Move RegA + data8 to 
RegA” 

Add data to register without 
carry and place the result in 
the SFBR register. Syntax: 
“Move RegA + data8 to 
SFBR” 

Add data to SFBR without 
carry and place the result in 
the register. Syntax: “Move 
SFBR + data8 to RegA” 

111 

Add data to register with 
carry and place the result in 
the same register. Syntax: 
“Move RegA + data8 to 

RegA with carry” 

Add data to register with 
carry and place the result in 
the SFBR register. Syntax: 
“Move RegA 4* dataS to 

SFBR with carry” 

Add data to SFBR with 
carry and place the result in 
the register. Syntax: “Move 
SFBR + data8 to RegA with 
carry” 


Notes: 

1 . Substitute the desired register name or address for “RegA” in the syntax examples 

2. dataS indicates eight bits of data 

3. Use SFBR instead of dataS to operate on two register values . 

* Data is shifted through the Carry bit and the Carry bit is shifted into the data byte 
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Instruction Set of the I/O Processor 

Transfer Control Instructions 


Transfer Control 
Instructions 


First Dword 

Bits 31-30 InstructionType - Transfer Control 
Instruction 

Bits 29-27 Op Code 

This 3-bit field specifies the type of transfer 
control instruction to be executed. All transfer 
control instructions can be conditional. They 
can be dependent on a true/false comparison 
of the ALU Carry bit or a comparison of the 
SCSI information transfer phase with the 
Phase field, and/or a comparison of the First 
Byte Received with the Data Compare field. 
Each instruction can operate in initiator or tar¬ 
get mode. 


Call Instruction 

1. The SYM53C895 can do a true/false 
comparison of the ALU carry bit, or compare 
the phase and/or data as defined by the Phase 
Compare, Data Compare, and True/False bit 
fields. If the comparisons are true, the 
SYM53C895 loads the DSP register with the 
contents of the DSPS register and that address 
value becomes the address of the next 
instruction. 

When the SYM53C895 executes a Call 
instruction, the instruction pointer contained 
in the DSP register is stored in the TEMP reg¬ 
ister. Since the TEMP register is not a stack 
and can only hold one dword, nested call 
instructions are not allowed. 

2. If the comparisons are false, the SYM53C895 
fetches the next instruction from the address 
pointed to by the DSP register and the 
instruction pointer is not modified. 


0PC2 

0PC1 

OPCO 

Instruction Defined 

0 

0 

0 

Jump 

0 

0 

1 

Call 

0 

1 

0 

Return 

0 

1 

1 

Interrupt 

1 

X 

X 

Reserved 


Jump Instruction 

1. The SYM53C895 can do a true/false 
comparison of the ALU carry bit, or compare 
the phase and/or data as defined by the Phase 
Compare, Data Compare and True/False bit 
fields. If the comparisons are true, the 
SYM53C895 loads the DSP register with the 
contents of the DSPS register. The DSP 
register now contains the address of the next 
instruction. 

2. If the comparisons are false, the SYM53C895 
fetches the next instruction from the address 
pointed to by the DSP register, leaving the 
instruction pointer unchanged. 
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Transfer Control Instructions 



Return Instruction 

1. The SYM53C895 can do a true/false 

comparison of the ALU carry bit, or compare 
the phase and/or data as defined by the Phase 
Compare, Data Compare, and True/False bit 
fields. If the comparisons are true, then the 
SYM53C895 loads the DSP register with the 
contents of the DSPS register. That address 
value becomes the address of the next 
instruction. 


When a Return instruction is executed, the 
value stored in the TEMP register is returned 
to the DSP register. The SYM53C895 does 
not check to see whether the Call instruction 
has already been executed. It will not generate 
an interrupt if a Return instruction is executed 
without previously executing a Call instruc¬ 
tion. 

2. If the comparisons are false, then the 

SYM53C895 fetches the next instruction from 
the address pointed to by the DSP register and 
the instruction pointer will not be modified. 
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Transfer Control Instructions 


Interrupt Instructions 

Interrupt 

a) The SYM53C895 can do a true/false 
comparison of the ALU carry bit, or 
compare the phase and/or data as defined 
by the Phase Compare, Data Compare, 
and True/False bit fields. If the 
comparisons are true, then the 
SYM53C895 generates an interrupt by 
asserting the IRQ/ signal. 

b) The 32-bit address field stored in the 
DSPS register (not DNAD as in 53C700) 
can contain a unique interrupt service 
vector. When servicing the interrupt, this 
unique status code allows the ISR to 
quickly identify the point at which the 
interrupt occurred. 

c) The SYM53C895 halts and the DSP 
register must be written to start any further 
operation. 

Interrupt on-the-Fly 

a) The SYM53C895 can do a true/false 
comparison of the ALU carry bit or 
compare the phase and/or data as defined 
by the Phase Compare, Data Compare, 
and True/False bit fields. If the 
comparisons are true, and the Interrupt on 
the Fly bit is set (bit 20), the SYM53C895 
will assert the Interrupt on the Fly bit 
(ISTAT bit 2). 

Bits 26-24 SCSI Phase 

This 3-bit field corresponds to the three SCSI 
bus phase signals which are compared with the 
phase lines latched when SREQ/ is asserted. 
Comparisons can be performed to determine 
the SCSI phase actually being driven on the 
SCSI bus. The following table describes the 
possible combinations and their correspond¬ 
ing SCSI phase. These bits are only valid when 
the SYM53C895 is operating in initiator 
mode; when the SYM53C895 is operating in 
the target mode, these bits should be cleared. 


MSG 

C/D 

I/O 

SCSI Phase 

0 

0 

0 

Data out 

0 

0 

1 

Data in 

0 

1 

0 

Command 

0 

1 

1 

Status 

1 

0 

0 

Reserved out 

1 

0 

1 

Reserved in 

1 

1 

0 

Message out 

1 

I 

1 

Message in 


Bit 23 Relative Addressing Mode 

When this bit is set, the 24-bit signed value in 
the DSPS register is used as a relative offset 
from the current DSP address (which is point¬ 
ing to the next instruction, not the one cur¬ 
rently executing). Relative mode does not 
apply to Return and Interrupt SCRIPTS. 


Jump/Call an Absolute Address 

Start execution at the new absolute address. 


Command 

Condition Codes 

Absolute Alternate Address 


Jump/Call a Relative Address 

Start execution at the current address plus (or 
minus) the relative offset. 


Command 

Condition Codes 

Don’t Care 

Alternate Jump Offset 


The SCRIPTS program counter is a 32-bit 
value pointing to the SCRIPT currently being 
executed by the SYM53C895.The next 
address is formed by adding the 32-bit pro¬ 
gram counter to the 24-bit signed value of the 
last 24 bits of the Jump or Call instruction. 
Because it is signed (twos compliment), the 
jump can be forward or backward. 
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Transfer Control Instructions 


A relative transfer can be to any address within 
a 16-MB segment. The program counter is 
combined with the 24-bit signed offset (using 
addition or subtraction) to form the new exe¬ 
cution address. 

SCRIPTS programs may contain a mixture of 
direct jumps and relative jumps to provide 
maximum versatility when writing SCRIPTS. 
For example, major sections of code can be 
accessed with far calls using the 32-bit physical 
address, then local labels can be called using 
relative transfers. If a SCRIPT is written using 
only relative transfers it would not require any 
run time alteration of physical addresses, and 
could be stored in and executed from a 
PROM. 

Bit 21 Carry Test 

When this bit is set, decisions based on the 
ALU carry bit can be made. True/False com¬ 
parisons are legal, but Data Compare and 
Phase Compare are illegal. 

Bit 20 Interrupt on the Fly 

When this bit is set, the interrupt instruction 
will not halt the SCRIPTS processor. Once the 
interrupt occurs, the Interrupt on the Fly bit 
(ISTAT bit 2) will be asserted. 

Bit 19 Jump IfTrue/False 

This bit determines whether the SYM53C895 
should branch when a comparison is true or 
when a comparison is false.This bit applies to 
phase compares, data compares, and carry 
tests. If both the Phase Compare and Data 
Compare bits are set, then both compares 
must be true to branch on a true condition. 
Both compares must be false to branch on a 
false condition. 


Bit 19 

Result of 
Compare 

Action 

0 

False 

Jump Taken 

0 

True 

No Jump 

1 

False 

No Jump 

1 

True 

Jump Taken 


Bit 18 Compare Data 

When this bit is set, the first byte received from 
the SCSI data bus (contained in SFBR regis¬ 
ter) is compared with the Data to be Com¬ 
pared Field in the Transfer Control instruction. 
The Wait for Valid Phase bit controls when this 
compare will occur. The Jump if True/False bit 
determines the condition (true or false) to 
branch on. 

Bit 17 Compare Phase 

When the SYM53C895 is in initiator mode, 
this bit controls phase compare operations. 
When this bit is set, the SCSI phase signals 
(latched by SREQ/) are compared to the Phase 
Field in the Transfer Control instruction; if 
they match, the comparison is true. The Wait 
for Valid Phase bit controls when the compare 
will occur.When the SYM53C895 is operating 
in target mode this bit, when set, tests for an 
active SCSI SATN/ signal. 

Bit 16 Wait For Valid Phase 

If the Wait for Valid Phase bit is set, the 
SYM53C895 waits for a previously unserviced 
phase before comparing the SCSI phase and 
data. 

If the Wait for Valid Phase bit is clear, the 
SYM53C895 compares the SCSI phase and 
data immediately. 

Bits 15-8 Data Compare Mask 

The Data Compare Mask allows a SCRIPT to 
test certain bits within a data byte. During the 
data compare, any mask bits that are set cause 
the corresponding bit in the SFBR data byte to 
be ignored. For instance, a mask of 01111111b 
and data compare value of lXXXXXXXb 
allows the SCRIPTS processor to determine 
whether or not the high order bit is set while 
ignoring the remaining bits. 

Bits 7-0 Data Compare Value 

This 8-bit field is the data to be compared 
against the SCSI First Byte Received (SFBR) 
register. These bits are used in conjunction 
with the Data Compare Mask Field to test for 
a particular data value. 
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Memory Move Instructions 


Second Dword 

Bits 31-0 Jump Address 

This 32-bit field contains the address of the 
next instruction to fetch when a jump is taken. 
Once the SYM53C895 has fetched the instruc¬ 
tion from the address pointed to by these 32 
bits, this address is incremented by 4, loaded 
into the DSP register and becomes the current 
instruction pointer. 


Memory Move Instructions 

For Memory Move instructions, bits 5 and 4 
(SIOM and DIOM) in the DMODE register 
determine whether the source or destination 
addresses reside in memory or I/O space. By set¬ 
ting these bits appropriately, data may be moved 
within memory space, within I/O space, or 
between the two address spaces. 

The Memory Move instruction is used to copy the 
specified number of bytes from the source address 
to the destination address. 

Allowing the SYM53C895 to perform memory 
moves frees the system processor for other tasks 
and moves data at higher speeds than available 
from current DMA controllers. Up to 16 MB may 
be transferred with one instruction. There are two 
restrictions: 

1. Both the source and destination addresses 
must start with the same address alignment 
(A(l-O) must be the same). If source and 
destination are not aligned, then an illegal 
instruction interrupt will occur. For the PCI 
Cache Line Size register setting to take effect, 
the source and destination must be the same 
distance from a cache line boundary. 

2. Indirect addresses are not allowed. A burst of 
data is fetched from the source address, put 
into the DMA FIFO and then written out to 
the destination address. The move continues 
until the byte count decrements to zero, then 
another SCRIPT is fetched from system 
memory. 


The DSPS and DSA registers are additional hold¬ 
ing registers used during the Memory Move; how¬ 
ever, the contents of the DSA register are 
preserved. 

Bits 31-39InstructionType—Memory Move 
Bits 28-25 Reserved 

These bits are reserved and must be zero. If 
any of these bits is set, an illegal instruction 
interrupt will occur. 

Bit 24 No Flush 

Note: this bit has no effect unless the Pre-fetch 
Enable bit in the DCNTL register is set. 
For information on SCRIPTS instruction 
prefetching, see Chapter 2. 

When this bit is set, the SYM53C895 performs a 
Memory Move without flushing the prefetch unit. 
When this bit is clear, the Memory Move instruc¬ 
tion automatically flushes the prefetch unit. The 
No Flush option should be used if the source and 
destination are not within four instructions of the 
current Memory Move instruction. 

Bits 23-0 Transfer Count 

The number of bytes to be transferred is stored 
in the lower 24 bits of the first instruction 
word. 


Read/Write System 
Memory from a Script 

By using the Memory Move instruction, single or 
multiple register values may be transferred to or 
from system memory. 

Because the SYM53C895 will respond to 
addresses as defined in the Base I/O or Base Mem¬ 
ory registers, it could be accessed during a Mem¬ 
ory Move operation if the source or destination 
address decodes to within the chip’s register space. 
If this occurs, the register indicated by the lower 
seven bits of the address is taken to be the data 
source or destination. In this way, register values 
can be saved to system memory and later restored, 
and SCRIPTS can make decisions based on data 
values in system memory. 
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N— DCMD Register — 

31 30 29 28 27 26 25 24 

< -DBC Register -► 

23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 







1 

J 

J 

1 

1 

I 

J 


1 






i 

1 

1 

I 

1 

I 

I 

1 



r 

r 

r 

TT 


J_ 






t 

I 

I 

E 

I 

L 

E 

L 







j_ 



1 — No Flush 
0 (Reserved) 

1 — 0 (Reserved) 
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1 — 0 (Reserved) 

0 - Instruction Type - Memory Move 
1 — 1 - Instruction Type - Memory Move 
1 — 1 - Instruction Type - Memory Move 


T 


24-bit Memoiy Move byte counter 


DSPS Register 

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 87 6 5 4 3 2 1 0 



TEMP Register 

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 



Figure 6-6: Memory Move Instructions 


The SFBR is not writable via the CPU, and there¬ 
fore not by a Memory Move. However, it can be 
loaded via SCRIPTS Read/Write operations. To 
load the SFBR with a byte stored in system mem¬ 
ory, the byte must first be moved to an intermedi¬ 
ate SYM53C895 register (for example, a 
SCRATCH register), and then to the SFBR. 

The same address alignment restrictions apply to 
register access operations as to normal memory-to- 
memory transfers. 
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Load and Store Instructions 


Second Dword 

Bits 31-0, DSPS Register 

These bits contain the source address of the 
Memory Move. 


Third Dword 

Bits 31-0, TEMP Register 

These bits contain the destination address for 
the Memory Move. 

Load and Store 
Instructions 

The Load and Store instruction provides a more 
efficient way to move data from/to memory to/from 
an internal register in the chip without using the 
normal memory move instruction. 

The load and store instructions are represented by 
two-dword op codes. The first dword contains the 
DCMD and DBC register values. The second 
dword contains the DSPS value. This is either the 
actual memory location of where to load or store, 
or the offset from the DSA, depending on the 
value of Bit 28 (DSA Relative). 

A maximum of 4 bytes may be moved with these 
instructions. The register address and memory 
address must have the same byte alignment, and 
the count set such that it does not cross dword 
boundaries. The destination memory address in 
the Store instruction and the source memory 
address of the Load instruction may not map back 
to the operating register set of the chip. This 
excludes the SCRIPTS RAM and ROM memory 
spaces. If it does, a PCI read/write cycle will occur 


(the data does not actually transfer to/from the 
chip), and the chip will issue an interrupt (Illegal 
Instruction Detected) immediately following. 

Bits A1, AO 

Number of bytes allowed to load/ 
store 

00 

One, two, three or four 

01 

One, two, or three 

10 

One or two 

11 

One 


The SIOM and DIOM bits in the DMODE regis¬ 
ter determine whether the destination or source 
address of the instruction is in Memory space or 1/ 
O space, as illustrated in the following table. The 
Load/Store utilizes the PCI commands for I/O 
READ and I/O WRITE to access the I/O space. 


Bit 

Source 

Destination 

SIOM (Load) 

memory 

register 

DIOM (Store) 

register 

memory 


First Dword 

Bit 31-29, Instruction Type 

These bits should be 111, indicating the Load and 
Store instruction. 

Bit 28, DSA Relative 

When this bit is clear, the value in the DSPS is 
the actual 32-bit memory address to perform 
the load/store to/from. When this bit is set, the 
chip determines the memory address to per¬ 
form the load/store to/from by adding the 24- 
bit signed offset value in the DSPS to the DSA. 

Bits 27-26, Reserved 

Bit 25, No Flush (Store instruction only) 

Note: this bit has no effect unless the Pre-fetch 
Enable bit in the DCNTL register is set. 
For information on SCRIPTS instruction 
prefetching, see Chapter 2. 


SYM53C895 Data Manual 


6-23 



Instruction Set of the I/O Processor 

Load and Store Instructions 


When this bit is set, the SYM53C895 performs 
a Store without flushing the prefetch unit. 
When this bit is clear, the Store instruction 
automatically flushes the prefetch unit. No 
Flush should be used if the source and destina¬ 
tion are not within four instructions of the cur¬ 
rent Store instruction.This bit is has no effect 
on the Load instruction. 

Bit 24, Load/Store 

When this bit is set, the instruction is a Load. 
When cleared, it is a Store. 

Bit 23, Reserved 

Bits 22-16, Register Address 

A6-A0 select the register to load/store to/from 
within the SYM53C895. 

Note: it is not possible to Load the SFBR 

register, although it is possible to Store the 
SFBR contents to another location. 

Bits 15-3, Reserved 
Bits 2-0, Byte Count 

This value is the number of bytes to load/store. 


Second Dword 

Bits 31-0, Memory/IO Address / DSA Offset 

This is the actual memory location of where to 
load or store, or the offset from the DSA register 
value. 
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Chapter 7 

Electrical Characteristics 


DC Characteristics 


Table 7-1: Absolute Maximum Stress Ratings 


Symbol 

Parameter 

Min 

Max 

Unit 

Test Conditions 

Tstg 

Storage temperature 

-55 

150 

°c 

- 

V D d 

Supply voltage 

-0.5 

5.0 

V 

- 

Vin 

Input Voltage 

Vss-0.3 

V DD + 03 

V 

- 

Ilp* 

Latch-up current 

± 150 

- 

mA 

- 

ESD** 

Electrostatic discharge 

- 

2K 

V 

MIL-STD 883 C 3 
Method 3015.7 


Stresses beyond those listed above may cause permanent damage to the device . These are stress ratings only; functional operation of 
the device at these or any other conditions beyond those indicated in the Operating Conditions section of the manual is not implied . 
* -2V < VpiN < 8V 
** SCSI pins only 


Table 7-2: Operating Conditions 


Symbol 

Parameter 

Min 

Max 

Unit 

Test Conditions 

V D d 

Supply voltage 

3.0 

3.6 

V 

- 


Supply current (dynamic) 

- 

130 

mA 

- 


Supply current (static) 

- 

1 

mA 

- 

Idd-scsi 

LVD pad supply current 

- 

600 

mA 

RBIAS = 2.2 K12, 
Vdd ~ 3.3 V 

T a 

Operating free air 

0 

70 

°C 

- 

Bja 

Thermal resistance (junc¬ 
tion to ambient air) 

- 

67 

°C/W 

- 

Conditions that exceed the operating limits may 

cause 

the device to function incorrectly 
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Table 7-3: SCSI Signals, Low Voltage Differential Drivers—SD (15-0)+/, SDP (1-0)+/-, SREQ+/-, SACK+/-, 
SMSG+/-, SIO+/-, SCD+/-, SATN+/-, SBSY+/-, SSEL+/-, SRST+/-* 


Symbol 

Parameter 

Min 

Max 

Units 

Test Conditions 

Io+ 

Source (+) current 

7 

9 

mA 

Asserted state 

V 

Sink (-) current 

-7 

-9 

mA 

Asserted state 

Io+ 

Source (+) current 

-3.5 

-4.5 

mA 

Negated state 

kr 

Sink (-) current 

3.5 

4.5 

mA 

Negated state 

kiz 

Tristate leakage 

-20 

20 

mA 


k)Z 

(SRST- 

only) 

Tristate leakage 

-500 

-50 

|iA 



y CM-0.7- 1.8V 

r l = o-iio a 

Rbias - 2.2 K il 



Table 7-4: SCSI Signals, Low Voltage Differential Receivers—SD (15-0)+/-, SDP (1-0)+/-, SREQ+/-, SACK+/-, 
SMSG+/-, SIO+/-, SCD+/-, SATN+/-, SBSY+/-, SSEL+/-, SRST+/-* 


Symbol 

Parameter 

Min 

Max 

Units 

Vi 

LVD receiver voltage asserting 

60 

- 

mV 

Vi 

LVD receiver voltage negating 

- 

-60 

mV 

V CM = 0.7- 

1.8V 
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Table 7-5: SCSI Signal —DIFFSENS 


Symbol 

Parameter 

Min 

Max 

Unit 

Test Conditions 

Vih 

High voltage differential 
sense voltage 

2.4 

Vdd + 0.3 

V 

- 

V s 

LVD sense voltage 

.7 

1.9 

V 

- 

Vjl 

Single-ended sense 
voltage 

Vss-0.3 

0.5 

V 

- 

J oz 

Tristate leakage 

-10 

10 

|iA 

- 


Table 7-6: SCSI Signals—KBIAS+/- 


Symbol 

Parameter 

Min 

Max 

Unit 

Test Conditions 

V, N 

Input voltage 

V DD 

, - 0.2 

V 

- 125pA 

Table 7-7: Capacitance 

Symbol 

Parameter 

Min 

Max 

Unit 

Test Conditions 

C I 

Input capacitance of 
input pads 

- 

7 

P F 

- 

C,o 

Input capacitance of I/O 
pads 

- 

15 

PF 

- 


Table 7-8: 

Output Signal— MAC/_TESTOUT 



Symbol 

Parameter 

Min 

Max 

Unit 

Test Conditions 

V OH 

Output high voltage 

2.4 

V DD 

V 

-16 mA 

V OL 

Output low voltage 

V ss 

0.4 

V 

16 mA 

loz 

Tristate leakage 

-10 

10 

pA 

- 
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Table 7-9: Input Signals—CLK*, RST/*, IDSEL, GNT/ 


Symbol 

Parameter 

Min 

Max 

Unit 

Test Conditions 

V, H 

Input high voltage 

0-5 V DD 

v dd + 0- 3 

V 

- 

Vil 

Input low voltage 

V ss - 0.3 

0.3 V dd 

V 

- 

J IN 

Input current 

-10 

10 

HA 

- 

J PULL 

Pull-up current 

25 

- 

pA 


* I PULL not possible 

Table 7- 

■10: Bidirectional Signals— 

AD(31-0), C_BE/(3-0), FRAME/, IRDY/, TRDY/, DEVSEL /, STOP/, PERR/, 
PAR, REQ / IRQ/, SERR/ 

Symbol 

Parameter 

Min 

Max 

Unit 

Test Conditions 

VlH 

Input high voltage 

0- 5 Vdd 

Vdd + 0-5 

V 

- 

Vil 

Input low voltage 

Vss-0.5 

0-3 V D d 

V 

- 

V OH 

Output high voltage 

09 V dd 

v dd 

V 

-500 pA 

V t )L 

Output low voltage 

Vss 

01 v DD 

V 

1500 pA 

I C)Z 

Tristate leakage 

-10 

10 

pA 

- 

IpULL 

Pull-up current 

25 


pA 


Table 7-11: Bidirectional Signals—GPIOO„FETCH/, 

GPI01_MASTER/, 

GPI02, GPI03, 

GPI04, MAD(7-0) 

Symbol 

Parameter 

Min 

Max 

Unit 

Test Conditions 

VlH 

Input high voltage 

2.0 

V D d + 0.5 

V 

- 

Vil 

Input low voltage 

Vss _ 0-5 

0.8 

V 

- 

V()H 

Output high voltage 

2.4 

V D d 

V 

-8 mA 

V OL 

Output low voltage 

Vss 

0.4 

V 

8 mA 

^OZ 

Tristate leakage 

-10 

10 ' 

pA 

- 
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Table 7-12: Bidirectional Signals—MAS/(l-0), MCE I, MOE I, MWE/ 


Symbol 

Parameter 

Min 

Max 

Unit 

Test Conditions 

Vih 

Input high voltage 

2.0 

Vdd + 0.5 

V 

- 

VlL 

Input low voltage 

v ss - 0.5 

0.8 

V 

- 

V OH 

Output high voltage 

2.4 

v dd 

V 

-4 mA 

V()L 

Output low voltage 

V S S 

0.4 

V 

4 mA 

If)Z 

Tristate leakage 

-10 

10 

HA 

- 

IpULL 

Pull-up current 

25 


ma 



Table 7-13: Input Signal— BIG_LIT/ 

Symbol 

Parameter 

Min 

Max 

Unit 

Test Conditions 

Vih 

Input high voltage 

2.0 

Vdd + 0.5 

V 

- 

Vjl 

Input low voltage 

Vss-0.5 

0.8 

V 

- 

!lN 

Input current 

-10 

10 

fiA 

- 

IpULL 

Pull-up current 

25 

- 

(iA 
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TolerANT Technology Electrical Characteristics 

Table 7-14: TolerANT Technology Electrical Characteristics 

Symbol 

Parameter 

Min 

Max 

Units 

Test Conditions 

Voh' 

Output high voltage 

2.0 

Vdd + 0-3 

V 

Iqh = 7 mA 

Vol 

Output low voltage 

Vss 

0.5 

V 

Iql = 48 mA 

Vih 

Input high voltage 

2.0 

V DD + 0.3 

V 

- 

Vil 

Input low voltage 

Vss -0.3 

0.8 

V 

Referenced to 

ViK 

Input clamp voltage 

-0.66 

-0.77 

V 

Vdd = 4.75; 

Ij = .20 mA 

V TH 

Threshold* high to low 

1.0 

1.2 

V 

- 

V TL 

Threshold* low to high 

1.4 

1.6 

V 

- 

v X h- 

V TL 

Hysteresis 

300 

500 

mV 

- 

Ioh' 

Output high current 

2.5 • 

24 

mA 

V OH = 2.5 V 

*OL 

Output low current 

100 

200 

mA 

V OL = 0.5 V 

Josh 1 

Short-circuit output 
high current 

— 

625 

mA 

Output driving low* 
pin shorted to Vpj} 
supply 2 

*osl 

Short-circuit output low 
current 

— 

95 

mA 

Output driving 
high* pin shorted to 
Vss supply 

Jlh 

Input high leakage 

- 

20 

HA 

-0.5 <V DD < 5.25 
VpiN = 2.7 V 

*ll 

Input low leakage 

- 

-20 

flA 

-0.5 <V DD < 5.25 
VpiN = 0.5V 

R, 

Input resistance 

20 

- 

Mil 

SCSI pins 3 

C P 

Capacitance per pin 

- 

15 

pF 

PQFP 

tR l 

Rise time* 10% to 90 % 

4.0 

18.5 

ns 

Figure 7-1 


Note:These values are guaranteed by periodic characterization; they are not 100% tested on every device. 
1 Active negat&m outputs only: Data, Parity, SREQt, SACK/ 

2 Single pin only; irreversible damage may occur if sustained far one second 
3 SCSI BESET pin has 10 Ml pull-up resistor 


7-6 


SYM53C895 Data Manual 



Electrical Characteristics 
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Table 7-14: TolerANT Technology Electrical Characteristics (Continued) 


Symbol 

Parameter 

Min 

Max 

Units 

Test Conditions 

l F 

Fall time, 90% to 10% 

4.0 

18.5 

ns 

Figure 7-1 

dV H /dt 

Slew rate, low to high 

0.15 

0.50 

V/ns 

Figure 7-1 

dV L /dt 

Slew rate, high to low 

0.15 

0.50 

V/ns 

Figure 7-1 

ESD 

Electrostatic discharge 

2 

- 

KV 

MIL-STD-883 C; 
3015-7 


Latch-up 

100 

- 

mA 

- 


Filter delay 

20 

30 

ns 

Figure 7-2 


Ultra filter delay 

10 

15 

ns 

Figure 7-2 


Ultra2 filter delay 

5 

8 

ns 

Figure 7-2 


Extended filter delay 

40 

60 

ns 

Figure 7-2 


Note: These values are guaranteed by periodic characterization; they are not 100% tested on every device. 
1 Active negation outputs only: Data , Parity, SREQf SACK/ 

2 Single pm only; irreversible damage may occur if sustained for one second 
3 SCSI RESET pm has 10 k£2 pull-up resistor 



Figure 7-3: Rise and Fall Time Test Conditions 



SYM53C895 Data Manual 


7-7 






OUTPUT SINK CURRENT (miiliAmperes) 















Electrical Characteristics 

AC Characteristics 


AC Characteristics 

The AC characteristics described in this section apply over the entire range of operating conditions (refer 
to the DC Characteristics section). Chip timings are based on simulation at worst case voltage* tempera¬ 
ture* and processing. Timings were developed with a load capacitance of 50 pF, 

Figure 7-8: External Clock Timing 

Symbol 

Parameter 

Min 

Max 

Units 


Bus clock cycle time 

30 

DC 

ns 


SCSI clock cycle time (SCLK)* 

25 

60 

ns 

l 2 

CLK low time** 

10 

- 

ns 


SCLK low time** 

6 

33 

ns 


CLK high time** 

12 

- 

ns 


SCLK high time** 

10 

33 

ns 

r 4 

CLK slew rate 

1 

- 

V/ns 


SCLK slew rate 

1 

- 

V/ns 


Timings are for an external 40 MHz clock. A quadrupled 40 MHz clock is required for Ultra2 SCSI operation , 
* This parameter must be met to insure SCSI timings are within specification 
**Duty cycle not to exceed 60140 


1.4V 

*-' 

c *3 ^ 

tl-► 


( ....s 

/ \ 

r»i i/ /r*r»i i/ / 


v 1 

\ 

ULK/oULK 

“►I 

◄-► 

*2 
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Electrical Characteristics 

PCI and External Memory Interface Timing Diagrams 


PCI and External Memory Interface Timing Diagrams 

Figure 7-11 through Figure 7-30 represent signal activity when the SYM53C895 accesses the PCI bus. 
This section includes timing diagrams for access to three groups of external memory configurations. The 
first group applies to systems with memory size of 64 KB and above; one byte read or write cycle, and fast 
or normal ROMs. The second group applies to systems with memory size of 64 KB and above, one-byte 
read or write cycles, and slow ROMs. The third group applies to systems with memory size of 64 KB or 
less, one-byte read or write cycles, and normal or fast ROM. 

Note: multiple byte accesses to the external memory bus increase the read or write cycle by 11 clocks for 
each additional byte. 

Timing diagrams included in this section 
Target Cycles 

■ PCI configuration register read 

■ PCI configuration register write 

■ Operating Register/SCRIPTS RAM read 

■ Operating Register/SCRIPTS RAM write 

■ External Memory Read 

■ External Memory Write 

Initiator Cycles 

■ Op code fetch, non-burst 

■ Burst op code fetch 

■ Back-to-back read 

■ Back-to-back write 

■ Burst read 

■ Burst write 

External Memory Cycles 

■ Read cycle, normal/fast memory (>128 KB), single-byte access 

■ Write cycle, normal/fast memory (> 128 KB), single-byte access 

■ Read cycle, normal/fast memory (> 128 KB), multiple-byte access 

■ Write cycle, normal/fast memory (> 128 KB), multiple-byte access 

■ Read cycle, slow memory (> 128 KB) 

■ Write cycle, slow memory >128 KB) 

■ Read cycle, 64 KB ROM 

■ Write cycle, 64 KB ROM 
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PCI and External Memory Interface Timing Diagrams 


Table 7-15: Configuration Register Read Timings 


Symbol 

Parameter 

Min 

Max 

Unit 

l i 

Shared signal input setup time 

7 

- 

ns 

l 2 

Shared signal input hold time 

0 

- 

ns 

h 

CLK to shared signal output valid 

- 

11 

ns 


M2 
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PCI and External Memory Interface Timing Diagrams 



Figure 7-11: PCI Configuration Register Read 
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PCI and External Memory Interface Timing Diagrams 


Table 7-16: Configuration Register Write Timings 


Symbol 

Parameter 

Min 

Max 

Unit 

h 

Shared signal input setup time 

7 

- 

ns 

l 2 

Shared signal input hold time 

0 

- 

ns 

% 

CLK to shared signal output valid 

- 

11 

ns 
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(Driven by Master) 


Figure 7-12; PCI Configuration Register Write 
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Table 7-17: Operating Register/SCRIPTS RAM Read Timings 


Symbol 

Parameter 

Min 

Max 

Unit 

l i 

Shared signal input setup time 

7 

- 

ns 

t 2 

Shared signal input hold time 

0 

- 

ns 

l 3 

CLK to shared signal output valid 

- 

11 

ns 
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Figure 7-13: Operating Register/SCRIPTS RAM Read 
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PCI and External Memory Interface Timing Diagrams 


Table 7-18: Operating Register/SCRIPTS RAM Write Timings 


Symbol 

Parameter 

Min 

Max 

Unit 

ti 

Shared signal input setup time 

7 

- 

ns 

t 2 

Shared signal input hold time 

0 

- 

ns 

% 

CLK to shared signal output valid 

- 

11 

ns 
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CLK 

(Driven by System) 


FRAME/ 
(Driven by Master) 

AD/ 1 

(Driven by Master) g 

C BE/ I 
(Driven by Master) | 

PAR / 

(Driven by Master) 

IRDY/ 

(Driven by Master) 


TRDY / 
(Driven by 53C895) 

STOP/ 

(Driven by 53C895) 

DEVSEL/ 
(Driven by 53C895) 
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Table 7-19: External Memory Read Timings 


Symbol 

Parameter 

Min 

Max 

Unit 

h 

Shared signal input setup time 

7 

- 

ns 

«2 

Shared signal input hold time 

0 

- 

ns 

*3 

CLK to shared signal output valid 

- 

11 

ns 

U 

Side signal input setup time 

10 

- 

ns 

hi 

Address setup to MAS/ high 

25 

- 

ns 


Address hold from MAS/ high 

15 

- 

ns 

t 13 

MAS/ pulse width 

25 

- 

ns 

t 14 

MCE/ low to data clocked in 

160 


ns 

*15 

Address valid to data clocked in 

205 

- 

ns 

t 16 

MOE/ low to data clocked in 

100 

- 

ns 

t 17 

Data hold from address, MOE/, MCE/ change 

0 

- 

ns 

*18 

Address out from MOE/, MCE/ high 

50 

- 

ns 

*19 

Data setup to CLK high 

5 

- 

ns 
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(Driven by System) ' 


FRAME/ 
(Driven by Master) 


AD 

(Driven by Master-Addr; 
53C895-Data) 

C_BE/ 

(Driven by Master) 
PAR 

(Driven by Master-Addr; 
53C895-Oata) 

IRDY/ 

(Driven by Master) 


TRDY 

(Driven by 53C895) 
STOP/ 

(Driven by 53C895) 

DEVSEt/ 
(Driven by 53C895) 


MAD 

{Driven by 53C895) 


MAS1/ 
(Driven by 53C895) 

MASO/ 
(Driven by 53C895) 

MCE/ 

(Driven by 53C895) 
MOE/ 

(Driven by 53C895) 
MWE/ 

(Driven by 53C895) 
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Table 7-20: External Memory Write Timings 


Symbol 

Parameter 

Min 

Max 

Unit 

h 

Shared signal input setup time 

7 

- 

ns 

l 2 

Shared signal input hold time 

0 

- 

ns 

l 3 

CLK to shared signal output valid 

- 

11 

ns 

tn 

Address setup to MAS/ high 

25 


ns 

r 12 

Address hold from MAS/ high 

15 

- 

ns 

t 13 

MAS/ pulse width 

25 

- 

ns 

l 20 

Data setup to MWE/ low 

30 

- 

ns 

r 21 

Data hold from MWE/ high 

20 

- 

ns 

r 22 

MWE/ pulse width 

100 


ns 


Address setup to MWE/ low 

75 

- 

ns 

Z 24 

MCE/ low to MWE/ high 

120 

- 

ns 

z 25 

MCE/ low to MWE/ low 

25 

- 

ns 

t 26 

MWE/ high to MCE/ high 

25 

- 

ns 
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« mRwr 
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MCE' 
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PCI and External Memory Interface Timing Diagrams 


Table 7-21: Op Code Fetch, non-burst Timings 


Symbol 

Parameter 

Min 

Max 

Unit 

h 

Shared signal input setup time 

7 

- 

ns 

r 2 

Shared signal input hold time 

0 

- 

ns 

l 3 

CLK to shared signal output valid 

2 

11 

ns 

l 4 

Side signal input setup time 

10 

- 

ns 

h 

Side signal input hold time 

0 

- 

ns 

tc, 

CLK to side signal output valid 

" 

12 

ns 

l 7 

CLK high to FETCH/ low 

- 

20 

ns 

% 

CLK high to FETCH/ high 

- 

20 

ns 

to 

CLK high to MASTER/ low 

- 

20 

ns 

t 10 

CLK high to MASTER/ high 

- 

20 

ns 
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Table 7-22: Burst Op Code Fetch Timings 


Symbol 

Parameter 

Min 

Max 

Unit 

h 

Shared signal input setup time 

7 

- 

ns 

Z 2 

Shared signal input hold time 

0 

- 

ns 

x 3 

CLK to shared signal output valid 

2 

11 

ns 

u 

Side signal input setup time 

10 

- 

ns 

*5 

Side signal input hold time 

0 

- 

ns 

*6 

CLK to side signal output valid 

- 

12 

ns 

l 7 

CLK high to FETCH/ low 

- 

20 

ns 

h 

CLK high to FETCH/ high 

- 

20 

ns 

r Q 

CLK high to MASTER/ low 

- 

20 

ns 

t 10 

CLK high to MASTER/ high 

- 

20 

ns 
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Table 7-23: 

Back to Back Read Timings 



Symbol 

Parameter 

Min 

Max 

Unit 

h 

Shared signal input setup time 

7 

- 

ns 

l 2 

Shared signal input hold time 

0 

- 

ns 

% 

CLK to shared signal output valid 

2 

11 

ns 

<4 

Side signal input setup time 

10 

- 

ns 

<5 

Side signal input hold time 

0 

- 

ns 

*6 

CLK to side signal output valid 

- 

12 

ns 

l t) 

CLK high to MASTER/ low 

- 

20 

ns 

t 10 

CLK high to MASTER/high 

- 

20 

ns 
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Table 7-24: Back to Back Write Timings 


Symbol 

Parameter 

Min 

Max 

Unit 

ti 

Shared signal input setup time 

7 

- 

ns 

l 2 

Shared signal input hold time 

0 

- 

ns 

*3 

CLK to shared signal output valid 

2 

11 

ns 

v 4 

Side signal input setup time 

10 

- 

ns 

*5 

Side signal input hold time 

0 

- 

ns 

t 6 

CLK to side signal output valid 

- 

12 

ns 

to 

CLK high to MASTER/ low 

- 

20 

ns 

t 10 

CLK high to MASTER/ high 

- 

20 

ns 
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Table 7*25: Burst Read Timings 


Symbol 

Parameter 

Min 

Max 

Unit 

h 

Shared signal input setup time 

7 

- 

ns 

*2 

Shared signal input hold time 

0 

- 

ns 

% 

CLK to shared signal output valid 

2 

11 

ns 

l 4 

Side signal input setup time 

10 

- 

ns 

*5 

Side signal input hold time 

0 

- 

ns 

*6 

CLK to side signal output valid 

- 

12 

ns 

to 

CLK high to MASTER/ low 

- 

20 

ns 

tio 

CLK high to MASTER/ high 

- 

20 

ns 
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Table 7-26: Burst Write Timings 


Symbol 

Parameter 

Min 

Max 

Unit 

ti 

Shared signal input setup time 

7 

* 

ns 

l 2 

Shared signal input hold time 

0 

- 

ns 

l 3 

CLK to shared signal output valid 

2 

11 

ns 

*4 

Side signal input setup time 

10 

- 

ns 

*5 

Side signal input hold time 

0 

- 

ns 

*6 

CLK to side signal output valid 

- 

12 

ns 

to 

CLK high to MASTER/ low 

- 

20 

ns 

tio 

CLK high to MASTER/ high 

- 

20 

ns 


7-34 


SYM53C895 Data Manual 



SYM53C895 Data Manual 7-35 



Electrical Characteristics 

PCI and External Memory Interface Timing Diagrams 



















Electrical Characteristics 

PCI and External Memory Interface Timing Diagrams 


Table 7-27: Read Cycle Timings, Normal/Fast Memory (>128 KB), single byte access 


Symbol 

Parameter 

Min 

Max 

Unit 

l n 

Address setup to MAS/ high 

25 

- 

ns 

*12 

Address hold from MAS/ high 

15 

- 

ns 

*13 

MAS/ pulse width 

25 

- 

ns 

<14 

MCE/ low to data clocked in 

160 

- 

ns 

*15 

Address valid to data clocked in 

205 

- 

ns 

*16 

MOE/ low to data clocked in 

100 

- 

ns 

*17 

Data hold from address, MOE/, MCE/ change 

0 

- 

ns 

*18 

Address out from MOE/, MCE/ high 

50 

- 

ns 

*19 

Data setup to CLK high 

5 

- 

ns 
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Table 7-28; Write Cycle Timings, Normal/Fast Memory (>128 KB), single byte access 


Symbol 

Parameter 

Min 

Max 

Unit 

tn 

Address setup to MAS/ high 

25 

- 

ns 

l \2 

Address hold from MAS/ high 

15 

- 

ns 

r 13 

MAS/ pulse width 

25 

- 

ns 

r 20 

Data setup to MWE/ low 

30 

- 

ns 

r 21 

Data hold from MWE/ high 

20 

- 

ns 

*■22 

MWE/ pulse width 

100 

- 

ns 

*23 

Address setup to MWE/ low 

75 

- 

ns 

*24 

MCE/ low to MWE/ high 

120 

- 

ns 


MCE/ low to MWE/ low 

25 

- 

ns 

*26 

MWE/ high to MCE/ high 

25 

- 

ns 
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Figure 7-24: Write Cycle, Normal/Fast Memory (> 128 KB), single byte access 
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| Figure 7-25: Read Cycle, Normal/Fast Memory (> 128 KB) multiple byte access 
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Figure 7-25: Read Cycle, Normal/Fast Memory (> 128 KB) multiple byte access (Continued) 
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Figure 7-26: Write Cycle, Normal/Fast Memory (> 128 KB), multiple byte access 
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Figure 7-26: Write Cycle, Normal/Fast Memory (> 128 KB), multiple byte access (Continued) 
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Table 7-29: Read Cycle Timings, Slow Memory (>128 KB) 


Symbol 

Parameter 

Min 

Max 

Unit 

tn 

Address setup to MAS/ high 

25 

- 

ns 

l \2 

Address hold from MAS/ high 

15 

- 

ns 

r 13 

MAS/ pulse width 

25 

- 

ns 

*14 

MCE/ low to data clocked in 

160 

- 

ns 

*15 

Address valid to data clocked in 

205 

- 

ns 

*16 

MOE/ low to data clocked in 

100 

- 

ns 

*17 

Data hold from address, MOE/, MCE/ change 

0 

- 

ns 

*18 

Address out from MOE/, MCE/ high 

50 

- 

ns 

*19 

Data setup to CLK high 

5 

- 

ns 
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Table 7-30: Write Cycle Timings, Slow Memory (>128 KB) 


Symbol 

Parameter 

Min 

Max 

Unit 

tn 

Address setup to MAS/ high 

25 

- 

ns 

r 12 

Address hold from MAS/ high 

15 

- 

ns 

t 13 

MAS/ pulse width 

25 

- 

ns 

l 20 

Data setup to MWE/ low 

30 

- 

ns 

l 2\ 

Data hold from MWE/ high 

20 

- 

ns 

r 22 

MWE/ pulse width 

100 

- 

ns 

t 23 

Address setup to MWE/ low 

75 

- 

ns 

*24 

MCE/ low to MWE/ high 

120 

- 

ns 

*25 

MCE/ low to MWE/ low 

25 

- 

ns 

l 26 

MWE/ high to MCE/ high 

25 

- 

ns 
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Figure 7-28: Write Cycle, Slow Memory (> 128 KB) 
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Table 7-31: Read Cycle Timings, < 64 KB ROM 


Symbol 

Parameter 

Min 

Max 

Unit 

tii 

Address setup to MAS/ high 

25 

- 

ns 

*12 

Address hold from MAS/ high 

15 

- 

ns 

*13 

MAS/ pulse width 

25 

- 

ns 


MCE/ low to data clocked in 

160 

- 

ns 

*15 

Address valid to data clocked in 

205 


ns 

*16 

MOE/ low to data clocked in 

100 

- 

ns 

*17 

Data hold from address, MOE/, MCE/ change 

0 

- 

ns 

*18 

Address out from MOE/, MCE/ high 

50 

- 

ns 

*16 

Data setup to CLK high 

5 

- 

ns 
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Table 7-32: Write Cycle Timings, < 64 KB ROM 


Symbol 

Parameter 

Min 

Max 

Unit 

tn 

Address setup to MAS/ high 

25 

- 

ns 

t 12 

Address hold from MAS/ high 

15 

- 

ns 

t 13 

MAS/ pulse width 

25 

- 

ns 

r 20 

Data setup to MWE/ low 

30 

- 

ns 

r 21 

Data hold from MWE/ high 

20 

- 

ns 

l 22 

MWE/ pulse width 

100 

- 

ns 

r 23 

Address setup to MWE/ low 

75 

- 

ns 

r 24 

MCE/ low to MWE/ high 

120 

- 

ns 

r 25 

MCE/ low to MWE/ low 

25 

- 

ns 

r 26 

MWE/ high to MCE/ high 

25 

" 

ns 
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Figure 7-30: Write Cycle, < 64 KB ROM 
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SCSI Timings 

Figure 7-31: Initiator Asynchronous Send 


Symbol 

Parameter 

Min 

Max 

Units 


SACK/ asserted from SREQ/ asserted 

5 

- 

ns 

l 2 

SACK/ deasserted from SREQ/ deasserted 

5 

- 

ns 

t 3 

Data setup to SACK/ asserted 

55 

- 

ns 

t 4 

Data hold from SREQ/ deasserted 

20 

- 

ns 



Figure 7-32: Initiator Asynchronous Receive 

Symbol Parameter Min Max Units 

tj SACK/ asserted from SREQ/ asserted 5 ns 

t 2 SACK/ deasserted from SREQ/ deasserted 5 ns 

t 3 Data setup to SREQ/ asserted 0 ns 

t 4 Data hold from SACK/ asserted 0 ns 
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Figure 7-33: Target Asynchronous Send 


Symbol 

Parameter 

Min 

Max 

Units 

ti 

SREQ/ deasserted from SACK/ asserted 

5 

- 

ns 

r 2 

SREQ/ asserted from SACK/ deasserted 

5 

- 

ns 

*3 

Data setup to SREQ/ asserted 

55 

- 

ns 


Data hold from SACK/ asserted 

20 

- 

ns 


i i 

SREQ / 

V " / 


^ n+1 





SACK/ 

1 \ » / 


^ n+1 


l^3-*l f* — 1 4 — ►] 



SD15-SD0, 

sdpi/.sdpo/ mm 

llll( Valid n \ 


Valid n+1 



Figure 7-34: Target Asynchronous Receive 

Symbol 

Parameter 

Min 

Max 

Units 

tj 

SREQ/ deasserted from SACK/ asserted 

5 

- 

ns 

l 2 

SREQ/ asserted from SACK/ deasserted 

5 

- 

ns 

r 3 

Data setup to SACK/ asserted 

0 

- 

ns 

C 4 

Data hold from SREQ/ deasserted 

0 

- 

ns 
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Figure 7-35: Initiator and Target Synchronous Transfers 


Table 7-33: SCSI-1 Transfers (Single-Ended, 5,0 MB/s) 


Symbol 

Parameter 

Min 

Max 

Units 

ti 

Send SREQ/ or SACK/ assertion pulse width 

90 

- 

ns 

*2 

Send SREQ/ or SACK/ deassertion pulse width 

90 

- 

ns 

tl 

Receive SREQ/ or SACK/ assertion pulse width 

90 

- 

ns 

t 2 

Receive SREQ/ or SACK/ deassertion pulse width 

90 

- 

ns 

% 

Send data setup to SREQ/ or SACK/ asserted 

55 

- 

ns 

u 

Send data hold from SREQ/ or SACK/ asserted 

100 

- 

ns 

*5 

Receive data setup to SREQ/ or SACK/ asserted 

0 

- 

ns 

r 6 

Receive data hold from SREQ/ or SACK/ asserted 

45 

- 

ns 
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Table 7-34: SCSI-1 Transfers (Differential, 4.17 MB/s) 


Symbol 

Parameter 

Min 

Max 

Units 

ti 

Send SREQ/ or SACK/ assertion pulse width 

96 

- 

ns 

H 

Send SREQ/ or SACK/ deassertion pulse width 

96 

- 

ns 

h 

Receive SREQ/ or SACK/ assertion pulse width 

84 

- 

ns 

l 2 

Receive SREQ/ or SACK/deassertion pulse width 

84 

- 

ns 

l 3 

Send data setup to SREQ/ or SACK/ asserted 

65 

- 

ns 

l 4 

Send data hold from SREQ/ or SACK/ asserted 

110 

- 

ns 

% 

Receive data setup to SREQ/ or SACK/ asserted 

0 

- 

ns 

% 

Receive data hold from SREQ/ or SACK/ asserted 

45 

- 

ns 

Table 7-35: 

SCSI-2 Fast Transfers 10.0 MB/s (8-bit transfers) or 20.0 MB/s (16-bit transfers), 40 MHz clock 

Symbol 

Parameter 

Min 

Max 

Units 

ti 

Send SREQ/ or SACK/ assertion pulse width 

35 

- 

ns 

l 2 

Send SREQ/ or SACK/ deassertion pulse width 

35 

- 

ns 

h 

Receive SREQ/ or SACK/ assertion pulse width 

20 

- 

ns 

r 2 

Receive SREQ/ or SACK/ deassertion pulse width 

20 

- 

ns 

r 3 

Send data setup to SREQ/ or SACK/ asserted 

33 

- 

ns 

l 4 

Send data hold from SREQ/ or SACK/ asserted 

45 

- 

ns 

*5 

Receive data setup to SREQ/ or SACK/ asserted 

0 

- 

ns 

% 

Receive data hold from SREQ/ or SACK/ asserted 

10 

- 

ns 


SYM53C895 Data Manual 


7-55 


Electrical Characteristics 

SCSI Timings 


Table 7-36; SCSI-2 Fast Transfers 10*0 MB/s (8-bit transfers) or 20.0 MB/s (16-bit transfers), 50 MHz clock 


Symbol 

Parameter 

Min 

Max 

Unit 

ti 

Send SREQ/ or SACK/ assertion pulse width 

35 

- 

ns 

t 2 

Send SREQ/ or SACK/ deassertion pulse width 

35 

- 

ns 

tl 

Receive SREQ/ or SACK/ assertion pulse width 

20 

- 

ns 

t 2 

Receive SREQ/ or SACK/ deassertion pulse width 

20 

- 

ns 

% 

Send data setup to SREQ/ or SACK/ asserted 

33 

- 

ns 

*4 

Send data hold from SREQ/ or SACK/ asserted 

40** 

- 

ns 

t«i 

Receive data setup to SREQ/ or SACK/ asserted 

0 

- 

ns 


Receive data hold from SREQ/ or SACK/ asserted 

10 

- 

ns 


^Transfer period bits (bits 6-4 in the SXFER register) are set to zero and the Extra Clock Cycle of Data Setup bit (bit 7 in 
SCNTL1) is set. 

**Analysis of system configuration is recommended due to reduced driver skew margin in differential systems 
Note: for fast SCSI\ set the Toler ANT Enable bit (bit 7 in STEST3). 


Table 7-37: Ultra SCSI Single-Ended Transfers 20.0 MB/s (8-bit transfers) or 40.0 MB/s (16-bit transfers), 

quadrupled 40 MHz clock 


Symbol 

Parameter 

Min 

Max 

Unit 

ti 

Send SREQ/ or SACK/ assertion pulse width 

16 

- 

ns 

t 2 

Send SREQ/ or SACK/ deassertion pulse width 

16 

“ 

ns 

ti 

Receive SREQ/ or SACK/ assertion pulse width 

10 

- 

ns 

l 2 

Receive SREQ/ or SACK/ deassertion pulse width 

10 

- 

ns 

t 3 

Send data setup to SREQ/ or SACK/ asserted 

12 

- 

ns 

Z 4 

Send data hold from SREQ/ or SACK/ asserted 

17 

- 

ns 

*5 

Receive data setup to SREQ/ or SACK/ asserted 

0 

- 

ns 

*6 

Receive data hold from SREQ/ or SACK/ asserted 

6 

- 

ns 


^Transfer period bits (bits 6-4 in the SXFER register) are set to zero and the Extra Clock Cycle of Data Setup bit (bit 7 in 
SCNTL1) is set. 

Note: for fast SCSI\ set the TolerANT Enable bit (bit 7 in STEST3). During Ultra SCSI transfers , the value of the Extend REQ/ 
ACK Filtering bit (STEST2, bit 1) has no effect. 
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Table 7-38: Ultra SCSI High Voltage Differential Transfers 



20.0 MB/s (8-bit transfers) or 40.0 MB/s (16-bit transfers), 80 MHz clock 


Symbol 

Parameter 

Min 

Max 

Unit 

*i 

Send SREQ/ or SACK/ assertion pulse width 

16 

- 

ns 

x 2 

Send SREQ/ or SACK/ deassertion pulse width 

16 

- 

ns 

t] 

Receive SREQ/ or SACK/ assertion pulse width 

10 

- 

ns 

h 

Receive SREQ/ or SACK/ deassertion pulse width 

10 

- 

ns 

x 3 

Send data setup to SREQ/ or SACK/ asserted 

16 

- 

ns 

l 4 

Send data hold from SREQ/ or SACK/ asserted 

21 

- 

ns 

x 5 

Receive data setup to SREQ/ or SACK/ asserted 

0 

- 

ns 

*6 

Receive data hold from SREQ/ or SACK/ asserted 

6 

- 

ns 

^Transfer period bits (bits 6-4 in the SXFER register) are set to zero and the Extra Clock Cycle of Data Setup bit (bit 7 in 

SCNTL1) is set. 

Note: During Ultra SCSI transfers » the value of the Extend REQ/ACK Filtering bit (STEST2 y bit 1 ) has no effect. 

Table 7-39: Ultra2 SCSI Transfers 40.0 MB/s (8-bit transfers) or 80.0 MB/s (16-bit transfers), 

quadrupled 40 MHz clock 

Symbol 

Parameter 

Min 

Max 

Unit 


Send SREQ/ or SACK/ assertion pulse width 

8 

- 

ns 

X 2 

Send SREQ/ or SACK/ deassertion pulse width 

8 

- 

ns 

*1 

Receive SREQ/ or SACK/ assertion pulse width 

6 

- 

ns 

x 2 

Receive SREQ/ or SACK/ deassertion pulse width 

6 

- 

ns 

c 3 

Send data setup to SREQ/ or SACK/ asserted 

10 

- 

ns 

t 4 

Send data hold from SREQ/ or SACK/ asserted 

10 

- 

ns 


Receive data setup to SREQ/ or SACK/ asserted 

4.5 

- 

ns 

t 6 

Receive data hold from SREQ/ or SACK/ asserted 

4.5 

- 

ns 

* Transfer period bits (bits 6-4 in the SXFER register) are set to zero and the Extra Clock Cycle of Data Setup bit (bit 7 
SGNTL1) is set. 

Note: During Ultra2 SCSI transfers , the value of the Extend REQ/ACK Filtering bit (STEST2, bit 1) has no effect. 
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Appendix A 

Register Summary 


Register 00 (80) 

SCSI Control Zero (SCNTLO) 
Read/Write 


Register 02 (82) 

SCSI Control Two (SCNTL2) 
Read/Write 


ARBI 

ARBO 

START 

WATN 

EPC 

RES 

AAP 

TRG 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

1 1 

0 

0 

0 

X 

0 

0 


Bit 7 ARBI (Arbitration Mode bit 1) 

Bit 6 ARBO (Arbitration Mode bit 0) 

Bit 5 START (Start Sequence) 

Bit 4 WATN (Select with SATN/ on a Start Sequence) 

Bit 3 EPC (Enable Parity Checking) 

Bit 2 Reserved 

Bit 1 AAP (Assert SATN/ on Parity Error) 

Bit 0 TRG (Target Mode) 


Register 01 (81) 

SCSI Control One (SCNTL1) 
Read/W rite 


SDU 

CHM 

SLPMD 

SLPHBEN 

WSS 

VUEO 

VUE1 

WSR 

7 

6 

5 

4 

3 

2 

1 

0 

Default>» 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7 SDU (SCSI Disconnect Unexpected) 

Bit 6 CHM (Chained Mode) 

Bit 5 SLPMD (SLPAR Mode Bit) 

Bit 4 SLPHBEN (SLPAR High Byte Enable) 

Bit 3 WSS (Wide SCSI Send) 

Bit 2 VUE0 (Vendor Unique Enhancements bit 0) 

Bit 1 VUE1 (Vendor Unique Enhancements bit 1) 

Bit 0 WSR (Wide SCSI Receive) 


Register 03 (83) 

SCSI Control Three (SCNTL3) 
Read/Write 




DHP 

CON 

RST 

AESP 

IARB 

SST 

7 

6 

5 

4 

3 

2 

1 

0 

Default>» 

0 0 

0 

0 

0 

0 

0 

0 


ULTRA 

SCF2 

SCF1 

SCFO 

EWS 

CCF2 

CCF1 

CCFO 

7 

6 

5 

4 

3 

2 

1 

0 

Default>» 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7 EXC (Extra Clock Cycle of Data Setup) 

Bit 6 ADB (Assert SCSI Data Bus) 

Bit 5 DHP (Disable Halt on Parity Error or ATN) ( 

Target Only) 

Bit 4 CON (Connected) 

Bit 3 RST (Assert SCSI RST/ Signal) 

Bit 2 AESP (Assert Even SCSI Parity (force bad 

parity)) 

Bit 1 IARB (Immediate Arbitration) 

Bit 0 SST (Start SCSI Transfer) 


Bit 7 ULTRA (Ultra Enable) 

Bits 6-4 SCF2-0 (Synchronous Clock 

Conversion Factor) 

Bit 3 EWS (Enable Wide SCSI) 

Bits 2-0 CCF2-0 (Clock Conversion Factor) 


Register 04 (84) 

SCSI Chip ID (SCID) 
Read/Write 


RES 

RRE 

SRE 

RES 

ENC3 

ENC2 

ENC1 

ENCO 

7 

6 

5 

4 

3 

2 

1 

0 

Default>» 

X 0 

0 

X 

0 

0 

0 

0 


Bit 7 
Bit 6 

Bit5 
Bit 4 
Bits 3-0 


Reserved 

RRE (Enable Response to 
Reselection) 

SRE (Enable Response to Selection) 
Reserved 

Encoded Chip SCSI ID, bits 3-0 
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Register 05 (85) 

SCSI Transfer (SXFER) 
Read/Write 


w&Mm 


TPO 

M04 

M03 

M02 

M01 

MOO 

mm 

■S 

5 

4 

3 

2 

1 

0 

Default>» 







0 

0 

0 

0 

0 

0 

0 

0 

Bits 7-5 

TP2-0 (SCSI Synchronous Transfer Period) 

Bits 4-0 MO4-MO0 (Max SCSI Synchronous Offset) 


Register 06 (86) 






SCSI Destination ID (SDID) 




Read/Write 







RES 

RES 

RES 

RES 

ENC3 

ENC2 

ENC1 

ENCO 

7 

6 

5 

4 

3 

2 

1 

0 

Defau lt»> 







X 

X 

X 

X 

0 

0 

0 

0 

Bits 7-4 

Reserved 






Bits 3-0 

Encoded Destination SCSI ID 




Register 07 (87) 

General Purpose (GPREG) 

Read/Write 

RES 

RES 

RES 

GPI04 

GPI03 

GPI02 

GPI01 

GPIOO 

7 

6 

5 

4 

3 

2 

1 

0 

Defau lt»> 







X 

X 

X 

0 

X 

X 

X 

X 

Bits 7-5 

Reserved 






Bits 4-0 

GPIO4-GPIO0 (General Purpose) 



Register 08 (88) 






SCSI First Byte Received (SFBR) 




Read/Write 







1B7 

1B6 

1B5 

1B4 

1B3 

1B2 

1B1 

1B0 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 







0 

0 

0 

0 

0 

0 

0 

0 


Register 09 (89) 

SCSI Output Control Latch (SOCL) 
Read /Write 


REQ 

■a 

Attain 

SEL 


mmm 

C/D 

1/0 

7 

m 

n 

4 

m 

wm 

1 

0 

Defau lt»> 







0 

0 

0 

0 

0 

0 

0 

0 

Bit 7 

Bit 6 

Bit5 

Bit 4 

Bit 3 

Bit 2 

Bit 1 
BitO 

REQ(Assert SCSI REQ/ Signal) 
ACK(Assert SCSI ACK/ Signal) 
BSY (Assert SCSI BSY/ Signal) 
SEL(Assert SCSI SEL/ Signal) 
ATN(Assert SCSI ATN/ Signal) 
MSG(Assert SCSI MSG/ Signal) 
C/D (Assert SCSI C_D/ Signal) 

I/O (Assert SCSI 1.0/ Signal) 




Register 0A (8A) 

SCSI Selector ID (SSID) 

Read Only 

VAL 

7 

RES 

6 

RES 

5 

RES 

4 

ENID3 

3 

ENID2 

2 

ENID1 

1 

ENIDO 

0 

Default»> 

0 X 

X 

X 

0 

0 

0 

0 

Bit 7 

Bits 6-4 

Bits 3-0 

VAL (SCSI Valid) 

Reserved 

Encoded Destination SCSI ID 




Register 0B (8B) 






SCSI Bus Control Lines (SBCL) 




Read Only 







REQ 

ACK 

BSY 

SEL 

ATN 

MSG 

C/D 

1/0 

7 

6 

5 

4 

3 

2 

1 

0 

Defau lt»> 

X X 

X 

X 

X 

X 

X 

X 


Bit 7 

REQ (SREQ/ Status) 

Bit 6 

ACK (SACK/ Status) 

Bit5 

BSY (SBSY/ Status) 

Bit 4 

SEL (SSEL/ Status) 

Bit 3 

ATN (SATN/ Status) 

Bit 2 

MSG (SMSG/ Status) 

Bitl 

C/D (SC_D/ Status) 

BitO 

I/O (SI_0/ Status) 
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Register OC (8C) Register OF (8F) 

DMA Status (DSTAT) SCSI Status Two (SSTAT2) 

Read Only (Read Only) 



ABRT SSI SIR RES IID ILF1 0RF1 0LF1 FF4 SPL1 DM LDSC SDP1 

43210 76543210 

Default»> 

000X0 0000XX1X 


Bit 7 DFE (DMA FIFO Empty) 

Bit 6 MDPE (Master Data Parity Error) 

Bit 5 BF (Bus Fault) 

Bit 4 ABRT (Aborted) 

Bit 3 SSI (Single Step Interrupt) 

Bit 2 SIR (SCRIPTS Interrupt 

Instruction Received) 

Bit 1 Reserved 

Bit 0 IID (Illegal Instruction Detected) 


Register OD (8D) 

SCSI Status Zero (SSTATO) 
Read Only 



Bit 7 ILF (SIDL Least Significant Byte Full) 

Bit 6 ORF (SODR Least Significant Byte Full) 

Bit 5 OLF (SODL Least Significant Byte Full) 

Bit 4 AIP (Arbitration in Progress) 

Bit 3 LOA (Lost Arbitration) 

Bit 2 WOA (Won Arbitration) 

Bit 1 RST/ (SCSI RST/ Signal) 

Bit 0 SDPO/ (SCSI SDPO/ Parity Signal) 


Register OE (8E) 

SCSI Status One (SSTAT1) 
Read Only 



Defau lt»> 

0000XXXX 


Bit 7 ILF1 (SIDL Most Significant Byte Full) 

Bit 6 ORF1 (SODR Most Significant Byte Full) 

Bit 5 OLF1 (SODL Most Significant Byte Full) 

Bit 4 FF4 (FIFO Flags bit 4) 

Bit 3 SPL1 (Latched SCSI parity for SD15-8) 

Bit 2 DM (DIFFSENS Mismatch) 

Bit 1 LDSC (Last Disconnect) 

Bit 0 SDP1 (SCSI SDP1 Signal) 

Registers 10-13 (90-93) 

Data Structure Address (DS A) 

Read/Write 


Register 14 (94) 

Interrupt Status (ISTAT) 
(Read/Write) 


ABRT 

SRST 

| SIGP 

SEM 

CON 

INTF 

SIP 

DiP - 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7 ABRT (Abort Operation) 

Bit 6 SRST (Software Reset) 

Bit 5 SIGP (Signal Process) 

Bit 4 SEM (Semaphore) 

Bit 3 CON (Connected) 

Bit 2 INTF (Interrupt on the Fly) 

Bit 1 SIP (SCSI Interrupt Pending) 

Bit 0 DIP (DMA Interrupt Pending) 

Register 18 (98) 

Chip Test Zero (CTESTO) 

Read/Write 


Bits 7-4 FF3-FF0 (FIFO Flags) 

Bit 3 SDPOL (Latched SCSI Parity) 

Bit 2 MSG (SCSI MSG/ Signal) 

Bit 1 C/D (SCSI C_D/ Signal) 

Bit 0 I/O (SCSI I_0/ Signal) 


SYM53C895 Data Manual 


A-3 





















Register Summary 


Register 19 (99) 

Chip Test One (CTESTl) 
Read Only 


FMT3 

FMT2 

FMT1 

FMT0 

FFL3 

FFL2 

FFL1 

FFL0 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

1 1 

1 

1 

0 

0 

0 

0 


Bits 7-4 FMT3-0 (Byte Empty in DIMA FIFO) 
Bits 3-0 FFL3-0 (Byte Full in DMA FIFO) 


Register 1A (9A) 

Chip Test Two (CTEST2) 
Read/Write 


DDIR 

SIGP 

CIO 

CM 


TEOP 

DREQ 

DACK 

7 

6 

5 

4 

m 

2 

1 

0 

Defau lt»> 

0 0 

X 

X 

0 

0 

0 

1 


Bit 7 DDIR (Data Transfer Direction) 

Bit 6 SIGP (Signal Process) 

Bit 5 CIO (Configured as I/O) 

Bit 4 CM (Configured as Memory) 

Bit 3 SRTCH (SCRATCHA/B Operation) 

Bit 2 TEOP (SCSI True End of Process) 

Bit 1 DREQ (Data Request Status) 

Bit 0 DACK (Data Acknowledge Status) 


Register IB (9B) 

Chip Test Three (CTEST3) 
Read/Write 


V3 

V 2 

VI 

VO 

FLF 

CLF 

FM 

WRIE 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

X x 

X 

X 

0 

0 

0 

0 


Bits 7-4 V3-V0 (Chip revision level) 

Bit 3 FLF (Flush DIMA FIFO) 

Bit 2 CLF (Clear DMA FIFO) 

Bit 1 FM (Fetch Pin Mode) 

Bit 0 WRIE (Write and Invalidate Enable) 


Registers 1C-IF (9C-9F) 
Temporary (TEMP) 
Read/Write 


Register 20 (AO) 
DMA FIFO (DFIFO) 
Read/Write 


B07 

7 

B06 

6 

B05 

5 

B04 

4 

H 

B02 

2 

B01 

1 

BOO 

0 

Default»> 







X 

0 

0 

0 

0 

0 

0 

0 

Bits 7-0 

BO 7-BOO (Byte offset counter) 




Register 21 (Al) 

Chip Test Four (CTEST4) 
Read/Write 


nn 

ZMOD 

ZSD 

SRTM 


FBL2 

FBL1 

FBL0 

MM 

6 i 

5 

4 

MM 

2 

1 

0 

Default»> 







0 

0 

0 

0 

0 

0 

0 

0 

Bit 7 

Bit 6 
BU5 

Bit 4 

Bit 3 
Bits 2-0 

BDIS (Burst Disable) 

ZMOD (High Impedance Mode) 

ZSD (SCSI Data High Impedance) 

SRTM (Shadow Register Test Mode) 
MPEE (Master Parity Error Enable) 
FBL2-FBL0 (FIFO Byte Control 


Register 22 (A2) 

Chip Test Five (CTEST5) 
Read/Write 





ADCK 

BBCK 

DFS 

MASR 

DDIR 

BL2 

B09 

B08 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 







0 

0 

0 

0 

0 

X 

X 

X 

Bit 7 

Bit 6 
Bits 

Bit 4 

Bit 3 

Bit 2 
Bits 1-0 

ADCK (Clock Address Incrementor) 

BBCK (Clock Byte Counter) 

DFS (DIMA FIFO Size) 

MASR (Master Control for Set or Reset Pulses) 
DDIR (DMA Direction) 

BL2 (Burst Length bit 2) 

B09-8 


Register 23 (A3) 

Chip Test Six (CTEST6) 
Read/Write 


DF7 

DF6 

DFS 

DF4 

DF3 

DF2 

DF1 

DF0 

7 

6 

5 

4 

3 

2 

1 

0 


Default»> 

00000000 


Bits 7-0 DF7-DF0 (DIMA FIFO) 
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Registers 24-26 (A4-A6) 
DMA Byte Counter (DBC) 
Read/Write 


Register 27 (A7) 

DMA Command (DCMD) 
Read/Write 


Registers 28-2B (A8-AB) 
DMA Next Address (DNAD) 
Read/Write 


Registers 2C-2F (AC-AF) 
DMA SCRIPTS Pointer (DSP) 
Read/Write 


Registers 30-33 (B0-B3) 

DMA SCRIPTS Pointer Save (DSPS) 
Read/Write 


Registers 34-37 (B4-B7) 

Scratch Register A (SCRATCH A) 
Read/Write 


Register 38 (B8) 

DMA Mode (DMODE) 
Read/Write 


BL1 

BLO 

SIOM 

DIOM 

ER 

ERMP 

u_ 

O 

CD 

MAN 

7 

6 

5 

4 

3 

2 

1 

0 

Detail lt»> 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7-6 BL1-BL0 (Burst Length) 

Bit 5 SIOM (Source I/O-Memory Enable) 

Bit 4 DIOM (Destination I/O-Memory Enable) 

Bit 3 ERL (Enable Read Line) 

Bit 2 ERMP (Enable Read Multiple) 

Bit 1 BOF (Burst Op Code Fetch Enable) 

Bit 0 MAN (Manual Start Mode) 


Register 39 (B9) 

DMA Interrupt Enable (DIEN) 
Read/Write 


RES 


BF 

ABRT 

SSI 

SIR 

RES 

IID 

7 

■i 

5 

4 

3 

2 

1 

0 

Default»> 

X 0 

0 

0 

0 

0 

X 

0 


Bit 7 Reserved 

Bit 6 MDPE (Master Data Parity Error) 

Bit 5 BF (Bus Fault) 

Bit 4 ABRT (Aborted) 

Bit 3 SSI (Single -step Interrupt) 

Bit 2 SIR (SCRIPTS Interrupt 

Instruction Received 
Bit 1 Reserved 

Bit 0 HD (Illegal Instruction Detected) 


Register 3A (BA) 

Scratch Byte Register (SBR) 
Read/Write 


Register 3B (BB) 

DMA Control (DCNTL) 
Read/W rite 


CLSE 

PFF 

PFEN 

SSM 

IRQM 

STD 

IRQD 

COM 

7 

6 

5 

4 

3 

2 

1 

0 

Detail lt»> 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7 CLSE (Cache Line Size Enable) 

Bit 6 PFF (Pre-fetch Flush) 

Bit 5 PFEN (Pre-fetch Enable) 

Bit 4 SSM (Single-step Mode) 

Bit 3 IRQM (IRQ Mode) 

Bit 2 STD (Start DMA Operation) 

Bit 1 IRQD (IRQ Disable) 

Bit 0 COM (53C700 Compatibility) 


Register 3C-3F (BC-BF) 
Adder Sum Output (ADDER) 
Read Only 
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Register 40 (CO) 

SCSI Interrupt Enable Zero (SIENO) 
Read/Write 


Register 43 (C3) 

SCSI Interrupt Status One (SIST1) 
Read Only 


M/A 

CMP 

SEL 



UDC 

RST 

PAR 

7 

6 

5 

4 

3 

2 

1 

0 

Default>» 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7 M/A (SCSI Phase Mismatch - 

Initiator Mode; SCSI ATN 
Condition - Target Mode) 

Bit 6 CMP (Function Complete) 

Bit 5 SEL (Selected) 

Bit 4 RSL (Reselected) 

Bit 3 SGE (SCSI Gross Error) 

Bit 2 UDC (Unexpected Disconnect) 

Bit 1 RST (SCSI Reset Condition) 

Bit 0 PAR (SCSI Parity Error) 


Register 41 (Cl) 

SCSI Interrupt Enable One (SIEN1) 
Read/Write 


RES 

RES 

RES 

SBMC 

RES 

STO 

GEN 

HTH 

7 

6 

5 

4 

3 

2 

1 

0 

Detail lt»> 

X X 

X 

0 

X 

0 

0 

0 


Bits 7-5 Reserved 

Bit 4 SBMC (SCSI Bus Mode Change) 

Bit 3 Reserved 

Bit 2 STO (Selection or Reselection Time-out) 

Bit 1 GEN (General Purpose Timer Expired) 

Bit 0 HTH ( Handshake-to-Handshake Timer Expired) 


Register 42 (C2) 

SCSI Interrupt Status Zero (SISTO) 
Read Only 


M/A 

CMP 

SEL 

RSL 

SGE 

UDC 

RST 

PAR 

7 

6 

5 

4 

3 

2 

1 

0 

Defau lt»> 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7 M/A (Initiator Mode: Phase Mismatch; Target 

Mode: SATN/ Active) 

Bit 6 CMP (Function Complete) 

Bit 5 SEL (Selected) 

Bit 4 RSL (Reselected) 

Bit 3 SGE (SCSI Gross Error) 

Bit 2 UDC (Unexpected Disconnect) 

Bit 1 RST (SCSI RSTV Received) 

Bit 0 PAR (Parity Error) 


RES 

RES 

RES 

SBMC 


STO 

GEN 

HTH 

7 

6 

5 

4 

3 

2 

1 

0 

Detault»> 

X X 

X 

0 

X 

0 

0 

0 


Bits 7-5 Reserved 

Bit 4 SBMC (SCSI Bus Mode Change) 

Bit 3 Reserved 

Bit 2 STO (Selection or Reselection Time-out) 

Bit 1 GEN (General Purpose Timer Expired) 

Bit 0 HTH (Handshake-to-Handshake Timer Expired) 


Register 44 (C4) 

SCSI Longitudinal Parity (SLPAR) 
Read/Write 


Register 45 (C5) 

SCSI Wide Residue (SWIDE) 
Read/Write 


Register 46 (C6) 

Memory Access Control (MACNTL) 
Read/Write 


TYP3 

TYP2 

TYP1 

TYPO 

DWR 

DRD 

PSCPT 

SCPTS 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

1 1 

0 

1 

0 

0 

0 

0 


Bits 7-4 TYP3-0 (Chip Type) 

Bit 3 DWR (DataWR) 

Bit 2 DRD (DataRD) 

Bit 1 PSCPT (Pointer SCRIPTS) 

Bit 0 SCPTS (SCRIPTS) 


Register 47 (C7) 

General Purpose Pin Control (GPCNTL) 
Read/Write 


ME 

FE 

RES 

GPI04 

GPI03 

GPI02 

GPI01 

GPIOO 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

0 0 

X 

0 

1 

1 

1 

1 


Bit 7 Master Enable 

Bit 6 Fetch Enable 

Bit 5 Reserved 

Bits 4-2 GPI04_EN-GPI02_EN (GPIO Enable) 

Bits 1-0 GPIO!_EN- GPIOOJ5N (GPIO Enable) 
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Register 48 (C8) 

SCSI Timer Zero (STIMEO) 
Read /Write 


HTH 

HTH 

HTH 

HRH 

SEL 

SEL 

SEL 

SEL 

7 

6 

5 

4 

3 

2 

1 

0 

Defau lt»> 

0 0 

0 

0 

0 

0 

0 

0 


Bits 7-4 HTH (Handshake-to-Handshake Timer Period) 

Bits 3-0 SEL (Selection Time-Out) 


Register 49 (C9) 

SCSI Timer One (STIME1) 
Read/Write 


RES 

HTHBA 

GENSF 

HTHSF 

GEN3 

GEN2 

GEN1 

GEN0 

7 

6 

5 

4 

3 

2 

1 

0 

Defau lt»> 

X 0 

0 

0 

0 

0 

0 

0 


Bit 7 Reserved 

Bit 6 HTHBA (Handshake-to-Handshake Timer Bus 

Activity Enable) 

Bit 5 GENSF (General Purpose Timer Scale Factor) 

Bit 4 HTHSF (Handshake to Handshake Timer Scale 

Factor) 

Bits 3-0 GEN3-0 (General Purpose Timer Period) 

Register 4A (CA) 

Response ID Zero (RESPIDO) 

Read/Write 


Register 4D (CD) 

SCSI Test One (STEST1) 
Read/Write 



Default»> 

0 0 X X 0 0 X X 

Bit 7 SCLK 

Bit 6 SISO (SCSI Isolation Mode) 

Bits 5-4 Reserved 

Bit 3 QEN (SCLK Quadrupler Enable) 

Bit 2 QSEL (SCLK Quadrupler Select) 

Bits 1 -0 Reserved 


Register 4E (CE) 

SCSI Test Two (STEST2) 
Read/Write 



Default»> 

0 0 0 0 0 0 0 0 

Bit 7 SCE (SCSI Control Enable) 

Bit 6 ROF (Reset SCSI Offset) 

Bit 5 DIF (SCSI Differential Mode) 

Bit 4 SLB (SCSI Loopback Mode) 

Bit 3 SZM (SCSI High-Impedance Mode) 

Bit 2 AWS (Always Wide SCSI) 

Bit 1 EXT (Extend SREQ/SACK Filtering) 

Bit 0 LOW (SCSI Low level Mode) 


Register 4B (CB) 

Response ID One(RESPIDl) 
Read/Write 


Register 4C (CC) 

SCSI Test Zero (STESTO) 
Read Only 


SSAID3 

SSAID2 SSAID1 

SSAID0 

SLT 

ART 

SOZ SOM 

7 

6 5 

4 

3 

2 

1 0 

Defauit»> 

0 0 0 

0 

0 

X 

1 1 


Bits 7-4 SSAID (SCSI Selected As ID) 

Bit 3 SLT (Selection Response Logic Test) 

Bit 2 ART (Arbitration Priority Encoder Test) 

Bit 1 SOZ (SCSI Synchronous Offset Zero) 

Bit 0 SOM (SCSI Synchronous Offset Maximum) 


Register 4F (CF) 

SCSI Test Three (STEST3) 
Read/Write 


TE 

STR 

HSC 

DSI 

S16 

TTM 

1 CSF 

STW 

7 

6 

5 

4 

3 

2 

1 

0 

Default»> 

0 0 

0 

0 

0 

0 

0 

0 


Bit 7 TE (TolerANT Enable) 

Bit 6 STR (SCSI FIFO Test Read) 

Bit 5 HSC (Halt SCSI Clock) 

Bit 4 DSI (Disable Single Initiator Response) 

Bit 3 S16 (16-bit System) 

Bit 2 TTM (Timer Test Mode) 

Bit 1 CSF (Clear SCSI FIFO) 

Bit 0 STW (SCSI FIFO Test Write) 
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Register Summary 


Register 50-51 (D0-D1) 

SCSI Input Data Latch (SIDL) 
Read Only 


Register 52 (D2) 

SCSI Test 4 (STEST4) 
Read Only 


SMODE 

LOCK 

RES 

RES 

RES 

RES 

RES 

7 | 6 

5 

4 

3 

2 

1 

0 

Default>» 

X X 

0 

X 

X 

X 

X 

X 


Bit 7-6 SMODE (SCSI Mode) 

Bit 5 LOCK (Frequency Lock) 

Bits 4-0 Reserved 


Registers 54-55 (D4-D5) 

SCSI Output Data Latch (SODL) 
Read/Write 


Registers 58-59 (D8-D9) 
SCSI Bus Data Lines (SBDL) 
Read Only 


Registers 5C-5F (DC-DF) 

Scratch Register B (SCRATCHB) 
(Read/Write) 


Registers 60h-7Fh (EOh-FFh) 
Scratch Registers C-J 
(SCRATCHC-SCRATCHJ) 
Read/Write 
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Mechanical Drawing 


Appendix B 

Mechanical Drawing 



Pin 11ndicator 


208-Pin Plastic 
Quad Fiat Package (QFP) 


0.27 Max 
0.17 Min 



Illilllllllil!l!l!lll!lilllll!lll1l!lllllllllli!l!lllllllllllllllilll!lll 



Figure B-l: SYM53C895 Mechanical Drawing 


(all dimensions in millimeters) 
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Mechanical Drawing 
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External Memory Interface Diagram Examples 


Appendix C 

External Memory Interface Diagram Examples 



MAD Bus Sense Logic Enabled for 16 KB of slow memory (200 ns Device @ 33MHz) 

Figure C-l:16 K Interface With 200 ns Memory 
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External Memory Interface Diagram Examples 


Optional - for Flash Memory only, 



MAD Bus Sense Logic Enabled for 64 KB of fast memory (150 ns Device @ 33MHz) 


Figure 02:64 K Interface with 150 ns Memory 
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External Memory Interface Diagram Examples 


Optional - for Flash Memory only, 



MAD Bus Sense Logic Enabled for 256 KB of fast memory (150 ns Device @33MHz). 
The HCT374s may be replaced with HCT377S. 


Figure C-3:256 K Interface With 150 ns Memory 
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Figure C-4:512 K Interface With 150 ns Memory 


o 

i 


CO 

-< 

cn 

oa 

O 

oo 

CD 

cn 

O 
fij 
* ♦ 


=3 

C 

SU 


Optional - for Flash Memory only, 



MAD Bus Sense Logic Enabled for 512 KB of slow memory (150 ns Devices, additional time required for HCT139 ® 33MHz). 

The HCT374s may be replaced with HCT377s. 


External Memory Interface Diagram Examples 
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Index 


Numerics 

53C700 Compatibility bit 5-38 

A 

Abort Operation bit 5-23 
Aborted bit 5-18, 5-36 
Absolute Maximum Stress Ratings 7-1 
active negation 

see TolerANT Technology 
active termination 2-16 
ADDER register 5-38 
Adder Sum Output register 5-38 
Additional Interface Pins 4-11 
Address and Data Pins 4-6 
Always Wide SCSI bit 5-51 
Arbitation in Progress bit 5-20 
arbitration 

Arbitration in Progress bit 5-20 
Arbitration Mode bits 5-5 
arbitration pins 4-7 
Immediate Arbitration bit 5-8 
Lost Arbitration bit 5-20 
Won Arbitration bit 5-20 
Arbitration Mode bits 5-5 
Arbitration Priority Encoder Test bit 5-49 
Assert Even SCSI Parity bit 5-7 
Assert SATN/ on Parity Error bit 5-6 
Assert SCSI ACK/ Signal bit 5-16 
Assert SCSI ATN/ Signal bit 5-16 
Assert SCSI BSY/ Signal bit 5-16 
Assert SCSI CJD/ Signal bit 5-16 
Assert SCSI Data Bus bit 5-7 


Assert SCSI I_0 Signal bit 5-16 
Assert SCSI MSG/ Signal bit 5-16 
Assert SCSI REQ/ Signal bit 5-16 
Assert SCSI RST/ Signal bit 5-7 
Assert SCSI SEIV Signal bit 5-16 

B 

Big and Little Endian Support 2-7 

block diagram 1 -6 

Block Move Instructions 6-4 

Burst Disable bit 5-29 

Burst Length bits 5-31, 5-35 

Burst Op Code Fetch Enable bit 5-36 

Bus Fault bit 5-18, 5-36 

Byte Empty in DMA FIFO bit 5-25 

Byte Full in DMA FIFO bit 5-25 

Byte Offset Counter bits 5-28, 5-31 

c 

Cache Line Size Enable bit 5-37 
cache mode, see PCI cache mode 3-2 
chained block moves 2-24-2-26 
SODL register 2-25 
SWIDE register 2-25 
Wide SCSI Receive Bit 2-25 
Wide SCSI Send Bit 2-24 
Chained Mode bit 5-9 
Chip Revision Level bits 5-27 
Chip Test Five register 5-30 
Chip Test Four register 5-29 
Chip Test One register 5-25 
Chip Test Six register 5-31 
Chip Test Two register 5-26 
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Index 


Chip Test Zero register 5-25 

Chip Type bits 5-45 

Clear DMA FIFO bit 5-27 

Clear SCSI FIFO bit 5-53 

Clock Address Increment or bit 5-30 

Clock Byte Counter bit 5-30 

Clock Conversion Factor bits 5-11 

clock quadrupler. See SCSI clock quadrupler 

Clock Timing 7-9 

configuration registers. See PCI configuration reg¬ 
isters 

Configured as I/O bit 5-26 
Configured as Memory bit 5-26 
Connected bit 5-7, 5-23 
CTESTO register 5-25 
CTESTl register 5-25 
CTEST2 register 5-26 
CTEST4 register 5-29 
CTEST5 register 5-30 
CTEST6 register 5-31 

D 

Data Acknowledge Status bit 5-26 

data path 2-10 

Data Request Status bit 5-26 

Data Structure Address register 5-22 

Data Transfer Direction bit 5-26 

DataRD bit 5-45 

DataWR bit 5-45 

DBC register 5-32 

DCMD register 5-32 

DCNTL register 5-37 

Destination I/O-Memory Enable bit 5-35 

DFIFO register 5-28 

DIEN register 5-36 

DIF bit 5-51 

differential mode. See high-voltage differential 
mode 


DIFFSENS pin 4-10, 4-11 

DIFFSENS signal 4-9 

Disable Halt on Parity Error or ATN 5-7 

Disable Single Initiator Response bit 5-52 

disconnects 

SCSI data path 2-10 
DMA Byte Counter register 5-32 
DMA Command register 5-32 
DMA Control register 5-37 
DMA core 2-1 
DMA Direction bit 5-31 
DMA FIFO bits 5-31 
DMA FIFO Empty bit 5-18 
DMA FIFO register 5-28 
DMA FIFO Size bit 5-30 
DMA Interrupt Enable register 5-36 
DMA Interrupt Pending bit 5-24 
DMA Mode register 5-35 
DMA Next Address register 5-33 
DMA SCRIPTS Pointer register 5-33 
DMA SCRIPTS Pointer Save register 5-34 
DMA Status register 5-18 
DMODE register 5-35 
DNAD register 5-33 
DSA register 5-22 
DSP register 5-33 
DSPS register 5-34 
DSTAT register 5-18 

E 

Enable Parity Checking bit 5-6 
Enable Read Line bit 5-35 
Enable Read Multiple bit 5-35 
Enable Response to Reselection bit 5-12 
Enable Response to Selection bit 5-12 
Enable Wide SCSI bit 5-11 
Encoded Chip SCSI ID 5-12 
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Encoded Destination SCSI ID bit 5-17 
Encoded Destination SCSI ID bits 5-15 
Error Reporting Pins 4-8 
Extend SREQ/SACK Filtering bit 5-51 
external memory interface 2-4 
configuration 2-4 
flash ROM updates 2-4 
GPI04 bit 5-15 
memory sizes supported 2-4 
multiple byte accesses 7-11 
parallel ROM interface 2-4 
pins 4-13 
slow memory 2-5 
system requirements 2-4 
timings 7-35—51 

Extra Clock Cycle of Data Setup bit 5-7 

F 

Fetch Enable 5-45 
Fetch Pin Mode bit 5-27 
FIFO Byte Control bits 5-30 
FIFO Flags bits 5-20, 5-22 
Flush DMA FIFO bit 5-27 
Function Complete bit 5-39, 5-41 
functional signal grouping 4-3 

G 

general description 1-1 

General Purpose Pin Control register 5-45 

General Purpose register 5-15 

General Purpose Timer Expired bit 5-40, 5-42 

General Purpose Timer Period bits 5-48 

General Purpose Timer Scale Factor bit 5-47 

GPCNTL register 5-45 

GPIO Enable bit 5-45 

GPIO pins 4-12 

SDMS use of 5-15 
GPIO4-0 bits 5-15 
GPREG register 5-15 


H 

Halt SCSI Clock bit 5-52 

Handshake-to-Handshake Timer Bus Activity En¬ 
able bit 5-47 

Handshake-to-Handshake Timer Expired bit 5-40, 
5-43 

Handshake-to-Handshake Timer Period bit 5-46 
High Impedance Mode bit 5-29 
high voltage differential mode 

auto-switching with LVD and single-ended 
mode 2-13 

description 2-13 
DIFFSENS Mismatch bit 5-22 
DIFFSENS signal 4-11 
Fast SCSI timings 7-55 
SCSI pin descriptions 4-10 
SCSI-1 timings 7-55 
Ultra SCSI timings 7-57 
wiring diagram 2-15 

I 

I/O Instructions 6-8 
Illegal Instruction Detected bit 5-18 
Immediate Arbitration bit 5-8 
instruction prefetching 2-3 
no flush option 6-21, 6-23 
Pre-fetch Enable bit 5-37 
Pre-fetch Flush bit 5-37 
prefetch unit flushing 2-3 
instructions 

block move 6-4 
FO 6-8 

load and store 6-23 
memory move 6-21 
read/write 6-13 
transfer control 6-17 
Interface Control Pins 4-7 
internal RAM, see SCRIPTS RAM 
Interrupt on the Fly bit 5-24 
Interrupt Status register 5-23 
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Index 


interrupts 2-21 

fatal vs. non-fatal interrupts 2-22 
halting 2-23 
IRQ Disable bit 2-22 
masking 2-22 

sample interrupt service routine 2-24 
stacked interrupts 2-23 
timings 7-10 
IRQ Disable bit 5-38 
IRQ Mode bit 5-38 
ISTAT register 5-23 

L 

Last Disconnect bit 5-22 
Latched SCSI Parity bit 5-21 
Latched SCSI Parity for SD15-8 bit 5-22 
load and store instructions 6-23 
no flush option 6-23 

prefetch unit and Store instructions 2-3, 6-23 
Lost Arbitration bit 5-20 
low voltage differential. See LVDlink 
LVDlink 

benefits 1-2 
DC characteristics 7-2 
DIFFSENS pin 4-9 
operation 2-12 

SCSI Bus Mode Change bit 5-40, 5-42 
SCSI Mode bit 5-54 
SCSI pin descriptions 4-8 

M 

MACNTL register 5-45 

Manual Start Mode bit 5-36 

Master Control for Set or Reset Pulses bit 5-30 

Master Data Parity Error bit 5-18, 5-36 

Master Enable bit 5-45 

Master Parity Error Enable bit 5-30 

Max SCSI Synchronous Offset bits 5-14 


Memory Access Control register 5-45 
Memory Move instructions 6-21 

and SCRIPTS instruction prefetching 2-3 
No Flush option 2-3 
Memory Read Line command 3-5 
Memory Read Multiple command 3-5 
Memory Write and Invalidate command 3-3 
Write and Invalidate Mode bit 3-8 

N 

new features in the SYM53C895 1-2 
No Flush Memory Move instruction 6-21 
No Flush Store instruction 6-23 

0 

op code fetch bursting 2-4 
Operating Conditions 7-1 
operating registers 

Adder Sum Output 5-38 

Chip Test Five 5-30 

Chip Test Four 5-29 

Chip Test One 5-25 

Chip Test Six 5-31 

Chip Test Three 5-27 

Chip Test Two 5-26 

Chip Test Zero 5-25 

Data Structure Address 5-22 

DMA Byte Counter 5-32 

DMA Command 5-32 

DMA Control 5-37 

DMA FIFO 5-28 

DMA Interrupt Enable 5-36 

DMA Mode 5-35 

DMA Next Address 5-33 

DMA SCRIPTS Pointer 5-33 

DMA SCRIPTS Pointer Save 5-34 

DMA Status 5-18 

general information 5-1 

General Purpose 5-15 
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General Purpose Pin Control 5-45 
Interrupt Status 5-23 
Memory Access Control 5-45 
register address map 5-4 
Response ID One 5-48 
Response ID Zero 5-48 
Scratch Byte 5-37 
Scratch Register A 5-34 
Scratch Register B 5-55 
Scratch Registers C-J 5-56 
SCSI Bus Control Lines 5-17 
SCSI Bus Data Lines 5-55 
SCSI Chip ID 5-12 
SCSI Control One register 5-7 
SCSI Control Register Two 5-9 
SCSI Control Three 5-10 
SCSI Control Zero 5-5 
SCSI Destination ID 5-15 
SCSI First Byte Received 5-16 
SCSI Input Data Latch 5-53 
SCSI Interrupt Enable One 5-40 
SCSI Interrupt Enable Zero 5-39 
SCSI Interrupt Status One 5-42 
SCSI Interrupt Status Zero 5-41 
SCSI Longitudinal Parity 5-43 
SCSI Output Control Latch 5-16 
SCSI Output Data Latch 5-54 
SCSI Selector ID 5-17 
SCSI Status One 5-20 
SCSI Status Two 5-21 
SCSI Status Zero 5-19 
SCSI Test Four 5-54 
SCSI Test One 5-50 
SCSI Test Three 5-52 
SCSI Test Two 5-51 
SCSI Test Zero 5-49 
SCSI Timer One 5-47 
SCSI Timer Zero 5-46 
SCSI Transfer 5-12 


SCSI Wide Residue 5-44 
Temporary Stack 5-28 

P 

Parity 2-8-2-9 
Parity Error bit 5-42 
PCI cache mode 3-2 

Cache Line Size Enable bit 5-37 
Cache Line Size register 3-11 
Enable Read Multiple bit 5-35 
Memory Read Line command 3-5 
Memory Read Multiple command 3-5 
Memory Write and Invalidate command 3-3 
Write and Invalidate Mode bit 3-8 

Write and Invalidate Enable bit 5-27 
PCI commands 3-1 
PCI Configuration registers 
Subsystem ID 3-12 
Subsystem Vendor ID 3-11 
PCI configuration registers 3-6-3-13 
Base Address One (Memory) 3-11 
Base Address Zero (I/O) 3-11 
Cache Line Size 3-11 
Class Code 3-10 
Command 3-8 
Device ID 3-8 

Expansion ROM Base Address 3-12 
Header Type 3-11 
Interrupt Line 3-12 
Interrupt Pin 3-12 
Latency Timer 3-11 
Max_Lat 3-13 
Min_Gnt 3-13 
Revision ID 3-10 
Status 3-9 
Vendor ID 3-8 
PCI configuration space 3-1 
PCI I/O space 3-1 
PCI memory space 3-1 


SYM53C895 Data Manual 


1-5 



Index 


Phase Mismatch bit 5-41 
pinout diagram 4-2 
pins 

additional interface pins 4-11 
address and data pins 4-6 
arbitration pins 4-7 
error reporting pins 4-8 
external memory interface pins 4-13 
functional signal grouping 4-3 
interface control pins 4-7 
SCSI pins 4-8, 4-9, 4-10 
system pins 4-6 
Pointer SCRIPTS bit 5-45 
Power and Ground Pins 4-5 
Pre-fetch Enable bit 5-37 
Pre-fetch Flush bit 5-37 
pull-ups, internal, conditions 4-4 

Q 

QEN bit 3 5-50 
QSELbit2 5-50 

quadrupling the SCSI clock frequency 5-50 

R 

RAM, see SCRIPTS RAM 
Read/Write Instructions 6-13 
register address map 
register addresses 
operating registers 
OOh 5-5 
Olh 5-7 
02h 5-9 
03h 5-10 
04h 5-12 
05h 5-12 
06h 5-15 
07h 5-15 
08h 5-16 
09h 5-16 


OAh 5-17 
OBh 5-17 
OCh 5-18 
ODh 5-19 
OEh 5-20 
OFh 5-21 
10-13h 5-22 
14h 5-23 
18h 5-25 
19h 5-25 
lAh 5-26 
lBh 5-27 
iC-lFh 5-28 
20h 5-28 
21h 5-29 
22h 5-30 
23h 5-31 
24-26h 5-32 
27h 5-32 
28-2Bh 5-33 
2C-2Fh 5-33 
30-33h 5-34 
34-37h 5-34 
38h 5-35 
39h 5-36 
3Ah 5-37 
3Bh 5-37 
3C-3Fh 5-38 
40h 5-39 
41h 5-40 
42h 5-41 
43h 5-42 
44h 5-43 
45h 5-44 
46h 5-45 
47h 5-45 
48h 5-46 
49h 5-47 
4Ah 5-48 
4Bh 5-48 
4Ch 5-49 
4Dh 5-50 
4Eh 5-51 
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4Fh 5-52 
50-5 lh 5-53 
54-55h 5-54 
58-59h 5-55 
5C-5Fh 5-55 
60-7Oh 5-56 

PCI configuration registers 
OOh 3-8 
02h 3-8 
04h 3-8 
06h 3-9 
08h 3-10 
09h 3-10 
OCh 3-11 
ODh 3-11 
OEh 3-11 
lOh 3-11 
14h 3-11 
18h 3-11 
30h 3-12 
3Ch 3-12 
3Dh 3-12 
3Eh 3-13 
3Fh 3-13 

Subsystem ID 3-12 
Subsystem Vendor ID 3-11 

register bits 

16-bit System 5-52 

53C700 Compatibility 5-38 

Abort Operation 5-23 

Aborted 5-18, 5-36 

Always Wide SCSI 5-51 

Arbitration in Progress 5-20 

Arbitration Mode 5-5 

Arbitration Priority Encoder Test 5-49 

Assert Even SCSI Parity (force bad parity)) 5-7 

Assert SATN/ on Parity Error 5-6 

Assert SCSI ACK/ Signal 5-16 

Assert SCSI ATN/ Signal 5-16 

Assert SCSI BSY/ Signal 5-16 

Assert SCSI C_D/ Signal 5-16 


Assert SCSI Data Bus 5-7 
Assert SCSI I_0/ Signal 5-16 
Assert SCSI MSG/ Signal 5-16 
Assert SCSI REQ/ Signal) 5-16 
Assert SCSI RST/ Signal 5-7 
Assert SCSI SEL/ Signal 5-16 
Burst Disable 5-29 
Burst Length 5-31, 5-35 
Burst Op Code Fetch Enable 5-36 
Bus Fault 5-18, 5-36 
Byte Empty in DMA FIFO 5-25 
Byte Full in DMA FIFO 5-25 
Byte Offset Counter 5-28, 5-31 
Cache Line Size Enable 5-37 
Chained Mode 5-9 
Chip Revision Level 5-27 
Chip Type 5-45 
Clear DMA FIFO 5-27 
Clear SCSI FIFO 5-53 
Clock Address Increment or 5-30 
Clock Byte Counter 5-30 
Clock Conversion Factor 5-11 
Configured as I/O 5-26 
Configured as Memory 5-26 
Connected 5-7, 5-23 
Data Acknowledge Status 5-26 
Data Request Status 5-26 
Data Transfer Direction 5-26 
DataRD 5-45 
DataWR 5-45 

Destination I/O-Memory Enable 5-35 

DIFFSENS Mismatch 5-22 

Disable Halt on Parity Error or ATN 5-7 

Disable Single Initiator Response 5-52 

DMA Direction 5-31 

DMA FIFO 5-31 

DMA FIFO Empty 5-18 

DMA FIFO Size 5-30 
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DMA Interrupt Pending 5-24 

Enable Parity Checking 5-6 

Enable Read Line 5-35 

Enable Read Multiple 5-35 

Enable Response to Reselection 5-12 

Enable Response to Selection 5-12 

Enable Wide SCSI 5-11 

Encoded Chip SCSI ID, bits 3-0 5-12 

Encoded Destination SCSI ID 5-15, 5-17 

Extend SREQ/SACK Filtering 5-51 

Extra clock cycle of data setup 5-7 

Fetch Enable 5-45 

Fetch Pin Mode 5-27 

FIFO Byte Control 5-30 

FIFO Flags 5-20, 5-22 

Flush DMA FIFO 5-27 

Frequency Lock 5-54 

Function Complete 5-39, 5-41 

General Purpose Timer Expired 5-40, 5-42 

General Purpose Timer Period 5-48 

General Purpose Timer Scale Factor 5-47 

GPIO Enable 5-45 ' 

GPIO4-0 5-15 
Halt SCSI Clock 5-52 

Handshake to Handshake Timer Scale Factor 
5-48 

Handshake-to-Handshake Timer Bus Activity 
Enable 5-47 

Handshake-to-Handshake Timer Expired 5- 
40, 5-43 

Handshake-to-Handshake Timer Period 5-46 

High Impedance Mode 5-29 

Illegal Instruction Detected 5-18 

Illegal instruction detected 5-36 

Immediate Arbitration 5-8 

Interrupt on the Fly 5-24 

IRQ Disable 5-38 

IRQ Mode 5-38 

Last Disconnect 5-22 

Latched SCSI Parity 5-21 


Latched SCSI Parity for SD15-8 5-22 

Lost Arbitration 5-20 

Manual Start Mode 5-36 

Master Control for Set or Reset Pulses 5-30 

Master Data Parity Error 5-18, 5-36 

Master Enable 5-45 

Master Parity Error Enable 5-30 

Max SCSI Synchronous Offset 5-14 

Parity Error 5-42 

Phase Mismatch 5-41 

Pointer SCRIPTS 5-45 

Pre-fetch Enable 5-37 

Pre-fetch Flush 5-37 

Reselected 5-39, 5-41 

Reset SCSI Offset 5-51 

SACK/ Status 5-17 

SATN/ Status 5-17 

SBSY/ Status 5-17 

SC_D/ Status 5-17 

SCLK 5-50 

SCLK Quadrupler Enable 5-50 
SCLK Quadrupler Enable bit 5-50 
SCLK Quadrupler Select 5-50 
SCLK Quadrupler Select bit 5-50 
SCRATCHA/B Operation 5-26 
SCRIPTS 5-45 

SCRIPTS Interrupt Instruction Received 5-18 

SCRIPTS interrupt instruction received 5-36 

SCSI Bus Mode Change 5-40, 5-42 

SCSI C_D/ Signal 5-21 

SCSI Control Enable 5-51 

SCSI Data High Impedance 5-29 

SCSI Differential Mode 5-51 

SCSI Disconnect Unexpected 5-9 

SCSI FIFO Test Read 5-52 

SCSI FIFO Test Write 5-53 

SCSI Gross Error 5-39, 5-41 

SCSI High-Impedance Mode 5-51 

SCSI I_0/ Signal 5-21 

SCSI Interrupt Pending 5-24 
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SCSI Isolation Mode 5-50 

SCSI Loopback Mode 5-51 

SCSI Low level Mode 5-51 

SCSI Mode 5-54 

SCSI MSG/Signal 5-21 

SCSI Parity Error 5-39 

SCSI Phase Mismatch - Initiator Mode 5-39 

SCSI Reset Condition 5-39 

SCSI RST/ Received 5-42 

SCSI RST/ Signal 5-20 

SCSI SDPO/ Parity Signal 5-20 

SCSI SDP1 Signal 5-22 

SCSI Selected As ID 5-49 

SCSI Synchronous Offset Maximum 5-49 

SCSI Synchronous Offset Zero 5-49 

SCSI Synchronous Transfer Period 5-12 

SCSI True End of Process 5-26 

SCSI Valid 5-17 

Select with SATN/ on a Start Sequence 5-6 
Selected 5-39, 5-41 

Selection or Reselection Time-out 5-40, 5-42 
Selection Response Logic Test 5-49 
Selection Time-Out 5-46 
Semaphore 5-23 

Shadow Register Test Mode 5-29 
SI_0/ Status 5-17 

SIDL Least Significant Byte Full 5-19 
SIDL Most Significant Byte Full 5-21 
Signal Process 5-23, 5-26 
Single Step Interrupt 5-18 
Single-step Interrupt 5-36 
Single-step Mode 5-37 
SLPAR High Byte Enable 5-9 
SLPAR Mode 5-9 
SMSG/ Status 5-17 
SODL Least Significant Byte Full 5-19 
SODL Most Significant Byte Full 5-21 
SODR Least Significant Byte Full 5-19 


SODRMost Significant Byte Full 5-21 

Software Reset 5-23 

Source I/O-Memory Enable 5-35 

SREQ/ Status 5-17 

SSEL/ Status 5-17 

Start DMA Operation 5-38 

Start SCSI Transfer 5-8 

Start Sequence 5-5 

Synchronous Clock Conversion Factor bits 
5-10 

Target Mode 5-6 
Timer Test Mode 5-52 
TolerANT Enable 5-52 
Ultra Enable 5-10 
Unexpected Disconnect 5-39, 5-42 
Vendor Unique Enhancements 0 5-9 
Vendor Unique Enhancements 1 5-10 
Wide SCSI Receive 5-10 
Wide SCSI Send 5-9 
Won Arbitration 5-20 
Write and Invalidate Enable 5-27 
Registers 

see operating registers 
Reselected bit 5-39, 5-41 
Reset Input 7-10 
Reset SCSI Offset bit 5-51 
RESPID0 register 5-48 
RESPID1 register 5-48 
Response ID One register 5-48 
Response ID Zero register 5-48 
Revision Level bits 5-27 

s 

SACK/ Status bit 5-17 
SATN/Active 5-41 
SATN/ Active bit 5-41 
SATN/ Status bit 5-17 
SBCL register 5-17 
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SBDL register 5-55 
SBR Register 5-37 
SBSY Status bit 5-17 
SC_D/ Status bit 5-17 
SCF2-0 bits 5-10 
SCID register 5-12 
SCLK bit 5-50 
SCNTLO register 5-5 
SCNTLl register 5-7 
SCNTL2 register 5-9 
SCNTL3 register 5-10 
Scratch Register 5-37 
SCRATCHA register 5-34 
SCRATCHA/B Operation bit 5-26 
SCRATCHB register 5-55 
SCRIPTS bit 5-45 

SCRIPTS Interrupt Instruction Received bit 5- 
SCRIPTS processor 2-1 

instruction prefetching 2-3 
internal RAM for instruction storage 2-2 
performance 2-1 
SCRIPTS RAM 2-2 

SCRATCHA/B Operation bit 5-26 
SCSI 

core 2-1 
LVDlink 2-12 
pins 4-8, 4-9, 4-10 
termination 2-16 
timings 7-52 

Toler ANT technology 1-3 
Ultra2 SCSI 2-2 

SCSI ATN Condition - Target Mode 5-39 
SCSI ATN Condition bit 5-39 
SCSI Bus Control Lines register 5-17 
SCSI Bus Data Lines register 5-55 
SCSI bus interface 2-12—2-18 
SCSI Bus Mode Change bit 5-40, 5-42 


SCSI C_D/ Signal bit 5-21 
SCSI Chip ID register 5-12 
SCSI CLK frequency 
quadrupling 5-50 
SCSI clock quadrupler 
QEN bit 5-50 
QSEL bit 5-50 
SCSI clock quadupler 

Frequency Lock bit 5-54 
SCSI clock rates 5-11 
SCSI Control Enable bit 5-51 
SCSI Control One register 5-7 
SCSI Control Three register 5-10 
SCSI Control Two register 5-9 
SCSI Control Zero register 5-5 
SCSI core 2-1 

SCSI Data High impedance bit 5-29 
SCSI Destination ID register 5-15 
SCSI Differential Mode bit 5-51 
SCSI Disconnect Unexpected bit 5-9 
SCSI FIFO Test Read bit 5-52 
SCSI FIFO Test Write bit 5-53 
SCSI First Byte Received register 5-16 
SCSI Gross Error bit 5-39, 5-41 
SCSI High-Impedance Mode bit 5-51 
SCSII_0/ Signal bit 5-21 
SCSI Input Data Latch register 5-53 
SCSI instructions 
block move 6-4 
I/O 6-8 

load/store 6-23 
memory move 6-21 
read/write 6-13 
transfer control 6-17 
SCSI Interrupt Enable One register 5-40 
SCSI Interrupt Enable Zero register 5-39 
SCSI Interrupt Pending bit 5-24 


1-10 


SYM53C895 Data Manual 



Index 


SCSI Interrupt Status One register 5-42 
SCSI Interrupt Status Zero register 5-41 
SCSI Isolation Mode bits 5-50 
SCSI Longitudinal Parity register 5-43 
SCSI Loopback Mode bit 5-51 
SCSI Low Level Mode bit 5-51 
SCSI MSG/ Signal bit 5-21 
SCSI Output Control Latch register 5-16 
SCSI Output Data Latch register 5-54 
SCSI Parity Error bit 5-39 
SCSI Phase Mismatch bit 5-39 
SCSI Reset Condition bit 5-39 
SCSI RST/ Received bit 5-42 
SCSI RST/ Signal bit 5-20 
SCSI SCRIPTS operation 6-1 
sample instruction 6-2 
SCSI SDPO/ Parity Signal bit 5-20 
SCSI SDPl Signal bit 5-22 
SCSI Selected As ID bits 5-49 
SCSI Selector ID register 5-17 
SCSI Status One register 5-20 
SCSI Status Two register 5-21 
SCSI Status Zero register 5-19 
SCSI Synchronous Offset Maximun 5-49 
SCSI Synchronous Offset Zero bit 5-49 
SCSI Synchronous Transfer Period bits 5-12 
SCSI Test One register 5-50 
SCSI Test Three register 5-52 
SCSI Test Two register 5-51 
SCSI Test Zero register 5-49 
SCSI Timer One register 5-47 
SCSI Timer Zero register 5-46 
SCSI timings 7-52-7-57 
SCSI Transfer register 5-12 
SCSI True End of Process bit 5-26 
SCSI Valid bit 5-17 


SCSI Wide Residue register 5-44 
SDID register 5-15 

Select with SATN/ on a Start Sequence bit 5-6 
Selected bit 5-39, 5-41 

Selection or Reselection Time-out bit 5-40, 5-42 

Selection Response Logic Test bits 5-49 

Semaphore bit 5-23 

SFBR register 5-16 

Shadow Register Test Mode bit 5-29 

SI_0/ Status bit 5-17 

SIDL Least Significant Byte Full bit 5-19 

SIDLMost Significant Byte Full bit 5-21 

SIDL register 5-53 

SIEN0 register 5-39 

SIEN1 register 5-40 

SIGP bit 5-23, 5-26 

Single Step Interrupt bit 5-18 

single-ended mode 

SCSI pin descriptions 4-9 
Single-step Interrupt bit 5-36 
Single-step Mode bit 5-37 
SIST0 register 5-41 
SIST1 register 5-42 
SLPAR High Byte Enable 5-9 
SLPAR Mode bit 5-9 
SLPAR register 5-43 
SMSG/ Status bit 5-17 
SOCL Least Significant Byte Full bit 5-19 
SOCL register 5-16 

SODL Most Significant Byte Full bit 5-21 
SODL register 5-54 

SODR Least Significant Byte Full bit 5-19 
SODRMost Significant Byte Full bit 5-21 
Software Reset bit 5-23 
Source I/O-Memory Enable bit 5-35 
SREQ/ Status bit 5-17 
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SSEL/ Status bit 5-17 
SSID register 5-17 
SSTATO register 5-19 
SSTATl register 5-20 
SSTAT2 register 5-21 
Stacked Interrupts 2-23 
Start DMA Operation bit 5-38 
Start SCSI Transfer 5-8 
Start Sequence bit 5-5 
STESTO register 5-49 
STEST1 register 5-50 
STEST2 register 5-51 
STEST3 register 5-52 
STIMEO register 5-46 
STIME1 register 5-47 
SWIDE register 5-44 
SXFER register 5-12 
SYM53C895 

new features 1-2 

Synchronous Clock Conversion Factor bits 5-10 
Synchronous data transfer rates 2-18 
System Pins 4-6 

T 

target disconnect 

SCSI data path 2-10 
Target Mode bit 5-6 
TEMP register 5-28 
Temporary register 5-28 
termination 2-16 
Timer Test Mode bit 5-52 
timings 

back to back read 7-29 
back-to-back write 7-32, 7-34 
burst op code fetch 7-27 
burst read 7-32 
burst write 7-34 


clock 7-9 

external memory read 7-21 

external memory write 7-23 

interrupt output 7-10 

op code fetch, non-burst 7-25 

operating register/SCRIPTS RAM read 7-17 

operating register/SCRIPTS RAM write 7-19 

PCI 7-24, 7-26, 7-28, 7-30, 7-32 

PCI configuration register read 7-13 

PCI configuration register write 7-15 

read cycle, normal/fast memory, multiple byte 
access 7-40 

read cycle, normal/fast memory, single byte ac¬ 
cess 
7-36 

read cycle, slow memory 7-44 
reset input 7-10 
SCSI 7-52 
Ultra2 SCSI 7-56 

write cycle, normal/fast memory, multiple byte 
access 7-42 

write cycle, normal/fast memory, single byte 
access 7-38 

write cycle, slow memory 7-46 
ToierANT Enable bit 5-52 
TolerANT Technology 1-3 
benefits 1-3 

electrical characteristics 7-6 
Extend SREQ/SACK Filtering bit 5-51 
TolerANT Enable bit 5-52 
TP2-0 bits 5-12 

Transfer Control Instructions 6-17 

and SCRIPTS instruction prefetching 2-4 
transfer rate 

synchronous 2-18 

Synchronous clock conversion factor bits 5-10 
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u 

Ultra Enable bit 5-10 
Ultra2 SCSI 
benefits 1-3 

designing an Ultra2 SCSI system 2-2 
LVDlink 2-12 

Synchronous Clock Conversion Factor bits 
5-10 

Synchronous clock conversion factor bits 5-10 
timings 7-56 
Ultra Enable bit 5-10 
Unexpected Disconnect bit 5-39, 5-42 

V 

Vendor Unique Enhancements 0 bit 5-9 
Vendor Unique Enhancements 1 bit 5-10 

w 

WATN/ bit 5-6 

what is covered in this manual 1-1 
wide SCSI 

Always Wide SCSI bit 5-51 
chained block moves 2-24 
Chained Mode bit 5-9 
Enable Wide SCSI bit 5-11 
SWIDE register 5-44 
Wide SCSI Receive bit 5-10 
Wide SCSI Send bit 5-9 
Wide SCSI Receive bit 5-10 
Wide SCSI Send bit 5-9 
Won Arbitration bit 5-20 
Write and Invalidate Enable bit 5-27 
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Symbios Logic 
Sales Locations 


For literature on any Symbios Logic product or service, 

call our hotline toll-free 

1-800-856-3093 


North American Sales Locations 

Western Sales Area 

1731 Technology Drive, Suite 610 
San Jose, CA 95110 
(408) 441-1080 

3300 Irvine Avenue, Suite 255 
Newport Beach, CA 92660 
(714) 474-7095 

Eastern Sales Area 

8000 Townline Avenue, Suite 209 
Bloomington, MN 55438-1000 
(612) 941-7075 


International Sales Locations 

European Sales Headquarters 

Westendstrasse 193\III 
80686 Muenchen 
Germany 

011-49-89-547470-0 

Asia/Pacilic Sales Headquarters 

Marina Square #02-256 
No. 6 Raffles Boulevard 
Singapore, 0103 
011-65-3376323 


12377 Merit Dr., Suite 400 
Dallas,TX 75251 
(972) 503-3205 


92 Montvale Avenue, Suite 3500 
Stoneham, MA 02180-3623 
(617) 438-0043 


30 Mansell Court, Suite 220 
Roswell, GA 30076 
(404) 641-8001 
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